我是Rivets.js的新手。鉴于这一守则:
<div id="main">
<div>
<button rv-on-click="toggle">
Toggle
</button>
</div>
<div>
Dynamic headers sould be visible: {showDynamicHeaders}
</div>
<table>
<thead>
<tr>
<th>Fixed header</th>
<th>Fixed header</th>
<th rv-show="showDynamicHeaders" rv-each-item="items">
{item.name}
</th>
</tr>
</thead>
</table>
</div>var rvcontext = {};
var rview = rivets.bind($("#main"), rvcontext);
rvcontext.showDynamicHeaders = true;
rvcontext.items = [
{
name : "Dynamic header 1"
},{
name : "Dynamic header 2"
},{
name : "Dynamic header 3"
}
];
rvcontext.toggle = function(){
rvcontext.showDynamicHeaders = !rvcontext.showDynamicHeaders;
}根据showDynamicHeaders的值,我希望表的动态头是否会显示出来。但是它似乎不起作用;相反,标头是否可见取决于showDynamicHeaders的初始值,但是当更新值时,它们的可见性不会改变。
有关活生生的示例,请参见这把小提琴。
我做错什么了吗?
发布于 2016-04-01 00:39:08
尝试将rv-show移动到<table>标记,如下所示:
<table rv-show="showTable" >
<tbody>
<tr rv-each-item="items">
<td>{item.name}</td>
</tr>
<tbody>
</table>编辑:另一个选项是在每个选项中添加一个rv类标记,如下所示:
<div rv-each-i="data" rv-class-hide="i.a | neq 1">
{i.a} - {i.b} ({i.c})
</div>javascript:
var data = [
{a:1, b:"testing1", c:true},
{a:1, b:"testing1a", c:true},
{a:1, b:"testing1b", c:true},
{a:2, b:"testing2", c:false},
{a:2, b:"testing2a", c:true},
{a:50, b:"testing50", c:false}
];
rivets.formatters.neq = function(val, v2) { return val!=v2;};
$(document).ready(function() {
var $r = $('#rivets');
rivets.bind($r, {data:data});
});rv类方法的工作小提琴
发布于 2017-05-12 12:37:03
虽然与您的问题无关,但我在搜索rv-show时发现了这个问题,因为它在数组循环中不能工作--结果是rv-show绑定需要传递给它的布尔值或整数值。"0“或"1”总是求值为true,所以在我的例子中,我只是将数据转换为整数,它按预期工作。
只是补充说,如果有其他人在这个问题上与我有同样的原因,特别是在处理AJAX数据的时候。
https://stackoverflow.com/questions/36091060
复制相似问题