我在显示或映射Kendo TreeView的父对象和子对象的显示名时遇到了麻烦 .
以下内容用作数据源的基本设置:
<div id="list-of-devices"</div>
// somewhere in my script
var inline = new kendo.data.HierarchicalDataSource({
data: [
{
"DeviceGroupId": 1,
"DeviceGroupName": "Superdeluxe Devices",
"Devices": [
{
"DeviceId": 1000,
"DeviceName": "My First Device"
},
{
"DeviceId": 1001,
"DeviceName": "My Second Device"
}
]
}
],
schema: {
model: {
children: "Devices"
}
}
});
当我使用 .kendoTreeview
函数直接初始化树视图时,它可以工作 . 像这样:
// initialize the treeview
$("#list-of-devices").kendoTreeView({
dataSource: inline,
dataTextField: ["DeviceGroupName", "DeviceName"]
});
这部分的魔力是最后一行代码,我为组和子项设置了不同的 dataTextField . 再次,这是有效的!
但是,如果我将其转换为MVVM示例,我不确定如何正确设置它 .
MVVM示例:
<div id="container">
<div id="list-of-devices" class="devices"
data-role="treeview"
data-text-field="dataTextField" <!-- HOW TO DO THIS? -->
data-bind="source: data">
</div>
</div>
var viewModel = kendo.observable({
data: inline,
dataTextField: ["DeviceGroupName", "DeviceName"] // <-- HOW TO DO THIS?
});
kendo.bind($("#container"), viewModel);
虽然它确实有效,例如抛出没有错误,所有标签在我的树视图中显示为“未定义” .
问题是:如何相应地设置或绑定dataTextField以使树视图正确地吐出组和子项的名称?
1 回答
基本上,你应该做的是将其定义为:
将
data-text-field
设置为值,就好像它是一个JavaScript数组,但是在引号之间 . 无需在ObservableObject
中定义它 .在这里查看:http://jsfiddle.net/OnaBai/38pk73ty/