我可以每隔1000毫秒执行一次计算函数来获取我的UI中显示的每1000毫秒新的时间跨度值吗?
self.timespan = ko.computed(function() {
return self.orderTime() + " " + new Date();
});
答案 0 :(得分:1)
将new Date()
包裹在一个可观察的计时器中,并使用setInterval
每1000毫秒更新一次,例如:
function myViewModel() {
var self = this;
self.orderTime = ko.observable(new Date(2013,1,1,12,0,0));
self.timer = ko.observable(new Date());
self.timespan = ko.computed(function() {
return self.orderTime() + " " + self.timer();
});
window.setInterval(function() { self.timer(new Date()); }, 1000);
}
ko.applyBindings(new myViewModel());
如果您愿意,也可以始终将timer
可观察对象隐藏在ViewModel的范围内,具体取决于您是否要直接公开它。
请参阅this fiddle了解演示。