如下是我从Google上找到的一个例子,很是生动形象,我修改了部分代码,具体内容以下:javascript
对于$root 与$parent的区别:html
译:$root 是指ViewModel所应用于ko.applyBindings时所使用的DOM;java
译:$parent 是指当前DOM元素直接的外部父类(只有一层);app
Or, visually, from $data's perspective:ide
Or, in words of the relevant documentation:ui
对于三者的区别($root,$parent及$data):this
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> <html> <head> <title></title> <script type="text/javascript" src="knockout-3.4.0.js"></script> <style> th, td { padding: 10px; border: 1px solid gray; } </style> <script type="text/javascript"> window.onload = function () { vm.mainPerson(grandpa); grandpa.children.push(daddy); daddy.children.push(son1); daddy.children.push(son2); ko.applyBindings(vm); } var Person = function (name) { var self = this; self.name = ko.observable(name); self.children = ko.observableArray([]); } var ViewModel = function () { var self = this; self.name = 'root view model'; self.mainPerson = ko.observable(); } var vm; vm= new ViewModel(), grandpa = new Person('grandpa'), daddy = new Person('daddy'), son1 = new Person('marc'), son2 = new Person('john'); </script> <script type="text/html" id="person"> <tr> <td data-bind="text: $root.name"></td> <td data-bind="text: $parent.name"></td> <td data-bind="text: $data.name"></td> </tr> <!-- ko template: { name: 'person', foreach: children } --><!-- /ko --> </script> <table> <tr> <th>$root</th> <th>$parent</th> <th>$data</th> </tr> <!-- ko template: { name: 'person', data: mainPerson } --><!-- /ko --> </table> </head> <body> </body> </html>
具体页面呈现:spa
The $root is always the same. The $parent is different, depending on how deeply nested you are.3d
译:$root常常是相同的,而$parent是不一样的,而这种不一样主要取决于你嵌套的深度。code