关于如何在Knockout.js中使用实时搜索过滤功能,我有一个想法。但我有一种新的复杂要求,最终输出将如下所示…
当用户点击列出的搜索结果时,他可能会有另一组子列表,其中应该有'n‘次向下钻取!
我试着用简单的实时搜索过滤功能。我丢了一些东西。我不知道如何从Json加载多级数据,也不知道如何在knockout JS中进行绑定。
有什么想法吗?
发布于 2015-01-16 21:57:18
我偶然发现了类似的问题。理解Knockout如何检测哪个观察值会影响计算值,这一点很重要。我注意到,在所有示例中,都是在计算函数作用域中调用可观察对象。如果我在过滤函数(子作用域)上调用它,则计算结果不会更新。我尝试在计算函数的开头调用它们,这样过滤函数就可以通过相同作用域中的变量访问值。这似乎是有效的,并且每次可观察到的改变-计算更新。
在这里,我修改了您的计算,它会实时过滤所有字段。
self.filteredRecords = ko.computed(function () {
var idSearch = self.idSearch(),
nameSearch = self.nameSearch().toLowerCase(),
townSearch = self.townSearch();
return ko.utils.arrayFilter(self.records(), function (r) {
return r.id.toString().indexOf(idSearch) !== -1 &&
r.name.toLowerCase().indexOf(nameSearch) !== -1 &&
(r.homeTown === townSearch || townSearch === "");
});
});
http://jsfiddle.net/67kgm/127/
https://stackoverflow.com/questions/25608201
复制相似问题