我需要将目录延迟加载到dijit.Tree
中的dijit.form.Dialog
。
我得到了根目录,我可以将它们放入树中,根节点为“计算机”,
但我无法弄清楚如何让延迟加载工作。
当我点击一个节点时,我调用一个函数进行ajax调用以获取所选节点的子节点。我可以获取它们并将它们作为JSON渲染回gsp(我认为它们形成得很好)。但是当我试图将它们放入商店时,它失败了。我无法让store.newItem()
工作。无论如何,我真的不知道这是否是正确和最简单的方法。我搜查并尝试失败,不幸的是,我被困住了。
我用:
我如何将dataStore导入gsp:
File [] roots = File.listRoots()
def item = []
roots.each{
item << [
name : it.getAbsolutePath(),
path : it.getAbsolutePath(),
children : []
]
}
def store = [
identifier: 'path',
label: 'name',
items: item
]
def retVal = [store: store]
render retVal as JSON
商店,模型和树的定义:
function prepare(dataStore) {
var store = new dojo.data.ItemFileWriteStore({
data: dataStore
});
var treeModel = new dijit.tree.ForestStoreModel({
store: store,
rootId : "root",
rootLabel : "Computer",
childrenAttrs: ["children"]
});
var treeControl = new dijit.Tree({
id: 'directoryTree',
model: treeModel,
autoExpand: false,
onClick: loadDirectories
},
"treeOne");
}
这里是我试图编辑商店的代码,数据是一个列表:
data = [
[name: 'info', path: 'C:\temp\info', children: []]
[name: 'grmpf', path: 'C:\temp\grmpf', children: []]
...
]
for(i=0; i < data.length; i++){
store.newItem({name: data[i].name, path: data[i].path, children: data[i].children}, {parent: parent.path[0], attribute: 'children'});
store.save();
}
我尝试了这种方式,有一次,我删除了该项目,编辑了该项目并再次将其放入商店。但没有任何效果......
如果有人能给我任何见解,我将不胜感激!
答案 0 :(得分:0)
幸运的是,我发现了一个非常奇怪的问题......
好吧,我试过了:
store.newItem(jsObj, parent);
store.save();
解决方案:
model.newItem(jsObj, parent);
我没有将商品添加到商店,而是将其放入模型中,然后就可以了。 我真的不知道为什么。也许有人可以向我解释。 感谢