首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >Knockout:如何更新每个ko.mapping数组元素中的单个字段

Knockout:如何更新每个ko.mapping数组元素中的单个字段
EN

Stack Overflow用户
提问于 2014-09-10 13:57:59
回答 1查看 412关注 0票数 1

我有一个很大的可观察数组:

代码语言:javascript
运行
复制
self.data = ko.mapping.fromJS(bigdata)

我需要更新数据中每个元素的单个字段;

最简单的解决方案是

代码语言:javascript
运行
复制
self.showAll = function() {
    for(var i = 0; i<self.data().length; i++) {
        self.data()[i].visible(true);
    }
}

但它非常慢,因为它在每次更新后调用处理程序。建议使用如下代码:

代码语言:javascript
运行
复制
var items = ko.observableArray([]);
var underlyingArray = items();
for (var i = 0, j = underlyingArray.length; i < j; i++) {
    // work with underlyingArray
}
self.items.valueHasMutated();

但它不适用于ko.mapping对象。

现在我使用的代码如下

代码语言:javascript
运行
复制
var data = ko.mapping.toJS(self.data);
for(var i = 0; i<data.length; i++) {
  //
}
ko.mapping.fromJS(data, {}, self.data);

我不喜欢这样。也许还有更好的?有没有办法暂停所有的ko处理程序?

EN

回答 1

Stack Overflow用户

发布于 2014-09-10 18:19:38

您可以调整visible属性的映射,以便在创建时返回true

代码语言:javascript
运行
复制
self.data = ko.mapping.fromJS(bigdata,
{
     'visible': { update: function(options) { return true; }}
});

请参阅Documentation

票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/25758253

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档