在Knockout JS中处理多维数组的最佳方式是什么?
What is the best way of handling multi dimensional arrays in Knockout JS?
用Knockout处理多维数组的标准方法是什么?
假设你想用KnockoutJS生成一个动态表。表的行和列是由observablearray生成的。每个单元格内的数据也是可观察的(数据绑定到文本框)。每个细胞内的数据也需要通过敲除验证来验证。
我正在使用类似的东西来生成我的文本框的值:
data-bind="value: $root.qty[$index()][$parentContext.$index()]"
<tbody data-bind="foreach: $root.styleColors">
<tr>
<td data-bind="text: StyleColorName, visible: $root.showFirstColumn"></td>
<!-- ko foreach: $root.sizes -->
<td>
<input type="text" class="qty" data-bind="value: $root.qty[$index()][$parentContext.$index()]"/>
</td>
<!-- /ko -->
</tr>
</tbody>
它工作得很好,但我需要能够根据我正在编辑的项目动态更改数据。只要我改变了列数或行数,就会引起各种各样的问题。我使用节流扩展器减少了很多这样的问题,使渲染在渲染之前等待行和列都是可观察的。
每次更改当前编辑的项时,我使用简单的javascript数组重新生成qty[][]多维数组,每个实际值都是可观察的。
这是我遇到的一个典型问题的例子。对于这个特定的示例,我验证了数量值(单元格)的最小值和最大值。但是,当我重新绑定包含较少行或较少列的表时,我得到以下异常(未捕获的TypeError:无法读取未定义的属性"规则")。我正在更改行和列的observableArrays,绑定data-bind="$root.qty[$index()][$parentContext.$index()]"不再有效,因为其中一个索引超出了范围。
我错过了什么?
谢谢!
如果没有看到更多的视图模型代码,我无法真正回答您的问题,但是您的方法听起来很复杂。除非你能弄清楚如何控制knockout计算添加/删除的顺序,否则你将遇到索引问题。我来告诉你我是如何解决表格问题的。
也- ie,特别是8向下,是非常挑剔的javascript代码修改表。测试测试测试!
我基本上修改了sanderson的简单网格-我会检查一下,看看它是否适用于你。
https://github.com/SteveSanderson/knockout/tree/gh-pages/examples/resources而不是做一个多维数组,有一个数组是您的列,然后另一个数组为您的行。行数组中的每个项实际上是一个对象,不同的列名作为键,对象作为值。
所以…
//two columns
this.columns = ko.observableArray(["Column1","Column2"]);
//two Rows
this.rowData = ko.observableArray([
{Column1:{StyleColorName:"Top Left"},Column2:{StyleColorName:"Top Right"}},
{Column1:{StyleColorName:"Bottom Left"},Column2:{StyleColorName:"Bottom Right"}}
]);
和标记
<thead>
<tr>
<th data-bind="visible:showFirstColumn">First Column</th>
<!-- ko foreach: $root.sizes -->
<th data-bind="text:$data" ></th>
<!-- /ko -->
</tr>
</thead>
<tbody data-bind="foreach: rowData">
<tr>
<td data-bind="text: StyleColorName, visible: $root.showFirstColumn"></td>
<!-- ko foreach: columns -->
<td>
<input type="text" class="qty" data-bind="value:$parent[$data].StyleColorName()"/>
</td>
<!-- /ko -->
</tr>
</tbody>
- 在localhost Dev Box上测试JSONP请求的最佳方式
- 为react组件传递道具的最佳方式
- 让Webpack管理Quirky AMD定义的最佳方式
- 在承诺链中处理早期回报的最佳方式
- 在ng重复循环中显示条件内容的最佳方式是什么
- 在phonegap中为android调用onload函数的最佳方式
- 链接两个网页或网络应用程序的最佳方式
- 什么's是连接供应商js文件的最佳方式
- 什么's是在javascript中迭代项的最佳方式
- 在node.js中编写单元测试的最佳方式是什么
- 在页面上记录数据并实现pushstate()的最佳方式
- 使用AJAX在Rails中提交动态表单的最佳方式是什么
- 什么'这是加载jQuery的最佳方式
- 将大数组(字符串和类型数组的混合物)存储到blob或文件中/从blob或文件检索大数组的最佳方式
- 在网站上显示.mov作为加载屏幕的最佳方式
- 使用Angular存储用户以前是否选中过复选框,然后再调用它的最佳方式是什么
- 以角度渲染表中数据的最佳方式
- 删除集合中旧邮件/帖子的最佳方式
- 显示全屏Ajax加载程序的最佳方式
- PHP和JS中表单验证的最佳方式