我正在学习KnockoutJS,但我不明白$root
和$parent
的用法之间的区别。请参阅this jsfiddle,或下面的代码:
<div data-bind="foreach:mainloop">
$data Value: <span data-bind="text:$data.firstName"></span>
<span data-bind="text:$data.lastName"></span> --(1)
<br/>
$parent Value: <span data-bind="text:firstName"> </span>
<span data-bind="text:$parent.lastName"></span>
<br/>
$root Value: <span data-bind="text:firstName"></span>
<span data-bind="text:$root.lastName"></span>
<br/>
<hr/>
</div>
var mainLoopModel = function() {
var self = this; // Root Level scope
self.mainloop = ko.observableArray([{
'firstName': 'jhon'
}, {
'firstName': 'sam'
}]);
self.lastName = ko.observable('peters');
/*if you remove $data before lastName in note (1) you get undefined error because because mainloop dont have lastName root model has lastName so you have to access using parent or higher level */
}
ko.applyBindings(new mainLoopModel());
在上面的代码$root
和$parent
都用于相同的目的:指外范围可变。我只是想知道$root
和$parent
用法之间是否有区别?如果是,那么请帮助我理解正确用法的一个好例子。
你可以有父母/祖先的多个级别(例如''一个内部foreach' foreach')。 '$ parent'是*直接父母*,'$ root'是*最外面的父母*。 – DCoder
淘汰赛文档是相当不错的,请阅读相关章节:绑定上下文http://knockoutjs.com/documentation/binding-context.html – nemesv