JQuery在foreach循环中切换div



我使用的是knockback.js.我有一个值"项目"列表(值来自服务器)。<div class="hiddendivcontent"> .

显示这些值的内容。
<ul data-bind="foreach: projects" class="list-group">
     <li class="list-group-item" data-bind="click: function(data,event){CommunityView.showContents($data.pkey(),$data.folder(), data, event);}">
          <span style="border:0px;" class="glyphicon glyphicon-plus pull-right" data-toggle="dropdown" ></span>
          <ul class="dropdown-menu labellistdropdown" role="menu" style="min-width:200px;">
              <li>..</li>
          </ul>
          <div  class="hiddendivcontent">
              <ul data-bind= "foreach : $root.community()" class="list-group">
                   <ul data-bind = "foreach :items">
                     <li> <span data-bind="text:cname"></span></li>
                   </ul>   
              </ul>
           </div>    
    </li>  
 </ul> 

当单击"CommunityView.showContents()"时,"hiddendivcontent"获得值。换句话说,当单击该方法时应该显示"hiddendivcontent",否则它将保持隐藏状态。下面的代码是我使用的Jquery代码:

showContents : function(pk,rf,data,event){
            event.preventDefault();
            $('.hiddendivcontent').toggle(); 
    }

如果我使用上面的代码,则在所有列表项中填充值。我已经尝试了很多方法来切换div,但没有工作。谁能给我提点建议?

Thanks in advance

尝试使用knockout可见绑定。首先,当从服务器接收项目时,向每个项目添加isVisible observable:

$.get(..., function(projects){
    projects = $.map(projects, function(project) {
        project.isVisible = ko.observable(false);
        return project;
    });
    viewModel.projects = projects; // assign received projects to your view model
});

现在在你的标记使用visible绑定如下:

<div data-bind="visible: isVisible">
    <ul data-bind= "foreach : $root.community()" class="list-group">
        <ul data-bind = "foreach :items">
            <li> <span data-bind="text:cname"></span></li>
        </ul>   
    </ul>
</div> 

注意,您不再需要hiddendivcontent类了。最后一件事,在你的showContents做如下:

showContents: function(name, id, data, event) {
    data.isVisible(!data.isVisible());
}

看演示。我希望这就是你需要的。

这是我对这个问题的回答。

我已经为列表添加了一些引导图标。因此,当用户单击引导图标时,隐藏的ul(每次用户单击它时动态创建)应该显示。

$(".glyphicon ").click( function ( e ){ 
   e.preventDefault() // prevent default action - hash doesn't appear in url
    var target = $(e.target);
    if(target.hasClass("glyphicon-chevron-right")){
    $(e.target).toggleClass('glyphicon-chevron-right glyphicon-chevron-down');
    var $newList = $("<ul />");
        $newList.append("<ul class="+"hiddendivcontent"+">");
    for(var i = 1; i <=4; i++) {
        $newList.append("<li><span>" + "menu" + i + "</span></li>");
    }        
    $(this).closest("li").append($newList);
    }
    else if(target.hasClass("glyphicon-chevron-down")){
         $(e.target).toggleClass('glyphicon-chevron-right glyphicon-chevron-down');
        $(e.target).parent().find("ul").remove();
    }
} )
http://jsfiddle.net/usezpkj2/4/

相关内容

  • 没有找到相关文章

最新更新