2016-04-25 6 views
0

私はスケジュールでいくつかの同時セッションを持つ会議のウェブサイトを構築しています。 スクリーンショットでわかるように、セミナー3はセミナー1 & 2と同時に行われる予定ですが、それらは分かれています。以下は、該当するコードを親切に見つけてください。誰がその理由を教えてもらえますか?会議のウェブサイトのイベントスケジュールの動作

Screenshot of Event Schedule in my Website

_addNewContent = function (msg) { 
 
    var lastBlock = false; 
 
    var lastConcurrent = false; 
 
    if (_page == 1) { 
 
     _wrapper.html(''); 
 
    } 
 
    $.each(msg.sessions, function (i) { 
 
     if (lastBlock) { 
 
      var lastTime = lastBlock.find('.schedule__time').text(); 
 
      lastTime = lastTime.split('-'); 
 
      if ($.trim(lastTime[0]) == this.time) { 
 
       if (!lastConcurrent) { 
 
        lastConcurrent = $('<div class="schedule__concurrent"></div>').appendTo(_wrapper); 
 
       } 
 
       lastConcurrent.append(lastBlock); 
 
      } else { 
 
       if (lastConcurrent) { 
 
        lastConcurrent.append(lastBlock); 
 
        lastConcurrent = false; 
 
       } else { 
 
        _wrapper.append(lastBlock); 
 
       } 
 
      } 
 
     } 
 
     var newBlockString = '<div class="schedule__item ' + _dropdown + ' more-content__item">' + 
 
       '<time class="schedule__time" datetime="' + this.time + '">' + this.time + ' - ' + this.end_time + '</time>' + 
 
       '<h2 class="schedule__event">' + this.post_title + '</h2>' + 
 
       '<div class="schedule__details">'; 
 
     if (_dropdown) { 
 
      newBlockString += ' <a class="schedule__close" href="#"><i class="fa fa-times"></i></a>'; 
 
     } 
 
     newBlockString += '<a href="#" class="schedule__main-place"><i class="fa fa-location-arrow"></i> ' + this.location + '</a>' + 
 
       '<div class="schedule__layout">' + 
 
       '<div class="schedule__speakers-group">'; // schedule__speakers-group 
 

 
     $.each(this.speakers, function() { 
 
      var speaker_image = ''; 
 
      if (typeof (this.post_image[0]) !== 'undefined') { 
 
       speaker_image = 'background-image: url(' + this.post_image[0] + ')'; 
 
      } 
 
      var favourite = this.featured ? 'speakers-favorite speakers-favorite_small' : ''; 
 
      newBlockString += '<a href="' + this.url + '" class="schedule__speaker">' + // schedule__speaker 
 
        '<div class="schedule__speaker-pic ' + favourite + '" style="' + speaker_image + '">' + 
 
        '<span class="schedule__speaker-hover">' + msg.strings.view_profile + '</span>' + 
 
        '</div>' + 
 
        '<h3 class="schedule__speaker-name">' + this.post_title + '</h3>' + 
 
        '</a>'; // /schedule__speaker 
 
     }); 
 

 
     newBlockString += '</div>' + // /schedule__speakers-group 
 
       '<div class="schedule__info">' + 
 
       '<div class="schedule__text">' + this.post_excerpt + '</div>' + 
 
       '<div class="schedule__labels">'; 
 

 
     $.each(this.tracks, function() { 
 
      newBlockString += '<span class="label" style="background-color:' + this.color + ';">' + 
 
        this.name + 
 
        '</span> '; 
 
     }); 
 

 
     newBlockString += '</div>' + 
 
       '<a href="' + this.url + '" class="btn btn_7">' + msg.strings.more_info + '</a>' + 
 
       '</div>' + // /schedule__info 
 
       '</div>' + // /schedule__layout 
 
       '</div>' + // /schedule__details 
 
       '</div>'; // /schedule__item 
 

 
     var newBlock = $(newBlockString); 
 

 
     if (msg.sessions.length == 1 || msg.sessions.length == i + 1) { 
 
      _wrapper.append(newBlock); 
 
     } 
 
     lastBlock = newBlock; 
 

 
    }); 
 

 
    var newItems = _wrapper.find('.hidden'); 
 
    setTimeout(function() { 
 

 
     $.each($('.schedule__items'), function() { 
 

 
      new ScheduleOpen($(this)); 
 

 
     }); 
 

 
    }, 10); 
 

 
    setTimeout(function() { 
 
     _heightAnimation(msg.has_items, newItems); 
 
    }, 50); 
 
},

答えて

0

私はあなたのウェブサイトが最初にこの全体の機能を実行する前に、会議セッションの配列を読んで推測します。

そして、私が見つかりました。この部分

if (msg.sessions.length == 1 || msg.sessions.length == i + 1) { 
     _wrapper.append(newBlock); 
    } 

は、最後の会議セッションに同時なってきて会議セッションの一部、特に最後の配列項目を防ぐことがあります。

あなたは

if (msg.sessions.length == 1) { 
    _wrapper.append(newBlock); 
} 
if (msg.sessions.length == i + 1) { 
    if (lastConcurrent) { 
     lastConcurrent.append(newBlock); 
    } else { 
     _wrapper.append(newBlock); 
    } 
} 
にそれを変更することができます
関連する問題