我使用的是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/