如何解决dojox.grid.TreeGrid 和 dojo.store.Memory
我想将 dojox.grid.TreeGrid
与 dojo.store.Memory
一起使用。 (这是遗留代码。以前我使用 dojo.data.ItemFileWriteStore
。但是我在这个存储中遇到了问题,所以我想尝试一下较新的内存存储。)但是在添加子项时网格不会正确更新。这是我的方法:
require(['dijit/tree/ForestStoreModel','dojo/data/ObjectStore','dojo/store/Memory','dojo/store/Observable','dojox/grid/TreeGrid','dojo/domready!'],function(ForestStoreModel,ObjectStore,Memory,Observable,TreeGrid) {
var data = [
{
id: '1',name: 'one',value: 1,toplevel: true
},{
id: '2',name: 'two',value: 2,toplevel: true
}
];
var store = Memory({
data: data,getChildren: function(object)
{
return object.children;
}
});
var observableStore = Observable(store);
var objectStore = new ObjectStore({ objectStore: observableStore });
var model = new ForestStoreModel({
store: objectStore,query: { toplevel: true },childrenAttrs: [ 'children' ],mayHaveChildren: function(parent)
{
return parent.children && parent.children.length > 0;
}
});
var structure = [
{ name:'name',field: 'name',width: '50%' },{ name: 'value',field: 'value',];
var grid = new TreeGrid({
treeModel: model,structure: structure,autoHeight: true
},'gridNode');
grid.startup();
function add(object,parentId)
{
store.put(object);
var parent = store.get(parentId);
if(!parent.children) {
parent.children = [];
}
parent.children.push(object);
store.put(parent);
//objectStore.onSet(parent,'children',parent.children.slice(0,parent.children.length - 1),parent.children);
}
grid.beginUpdate();
add({ id: '1.1',name: 'one.one',value: 3 },'1');
add({ id: '1.2',name: 'one.two',value: 4 },'1');
add({ id: '1.2.1',name: 'one.two.one',value: 5 },'1.2');
add({ id: '2.1',name: 'two.one',value: 6 },'2');
grid.endUpdate();
});
这是一个小提琴:http://jsfiddle.net/wvbdsfa4/31/
用 objectStore.onSet
取消注释该行有帮助,但它似乎不完整(我需要触发更多事件)。我希望 dojo/store/Observable
为我做这件事。
我做错了什么?
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。