1

在这方面需要帮助,几天来一直在想办法让它工作。

参考这个演示http://jsfiddle.net/8QkEw/313/,我如何修改我的代码以使内部超链接在展开/选定 itemSelector 保持展开/选定时工作。

$(function(){


  var $container = $('#container'),
      $items = $('.item');

  $container.isotope({
    itemSelector: '.item',
    masonry: {
      columnWidth: 100
    },
    getSortData : {
      selected : function( $item ){
        // sort by selected first, then by original order
        return ($item.hasClass('selected') ? -500 : 0 ) + $item.index();
      }
    },
    sortBy : 'selected'
  })

  $items.click(function(){
    var $this = $(this);
    // don't proceed if already selected
    var $previousSelected = $('.selected');
    if ( !$this.hasClass('selected') ) {
      $this.addClass('selected');
    }

    $previousSelected.removeClass('selected');

    // update sortData for new items size
    $container
      .isotope( 'updateSortData', $this )
      .isotope( 'updateSortData', $previousSelected )
      .isotope();

  });

});

只有当用户点击内部超链接时,才会最小化展开/选中的框;点击其他区域仍然会触发$previousSelected.removeClass('selected');

提前致谢。

4

2 回答 2

2

停止链接上的事件传播:

$('.item a').click(function(event){
    event.stopPropagation();
});

这是一个演示:http: //jsfiddle.net/VCmNU/

于 2013-01-09T07:15:22.380 回答
2

您可以添加以下处理程序

 $('.item a').click(function(e){
     e.stopPropagation();
 });

工作样本在这里

于 2013-01-09T07:19:52.640 回答