作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有一个 Web 服务,可以传递包含其他数据的客户列表。我希望能够点击多个客户,将他们添加到我将在其他地方使用的数组中。再次点击它们会将它们从数组中移除。
在某些方面与此解决方案类似:
Highlight selected row using knockout
如果有人可以解释计算值与什么进行比较以及它是如何工作的,我想我可以自己搞定其余部分:
self.isSelected = ko.computed(function() {
return selected() === self;
});
最佳答案
您需要的是设置一个可观察的属性并在值更改时从数组中添加/删除。或者只是检查在任何时间点选择了哪一个。让我在 jsfiddle 中创建一个示例:http://jsfiddle.net/6FCEe/55/
Thing = function(id, name, selected) {
var self = this;
self.ID = id,
self.Name = name,
self.isSelected = ko.observable(false);
self.isSelected.subscribe(function (selected){
if (selected){
// Add to array
} else {
// Remove from array
}
});
};
并将 onClick 事件更新为:
self.selectThing = function(item) {
item.isSelected(!item.isSelected());
};
关于javascript - 在 knockout js 中通过单击突出显示行,并将数据传递到新数组,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16613579/
有没有一种方法可以“标记”对象的属性,使它们在反射中“突出”? 例如: class A { int aa, b; string s1, s2; public int AA
我是一名优秀的程序员,十分优秀!