Dojo是一個(gè)JavaScript的工具庫,它提供了很多實(shí)用的工具方便開發(fā)者使用,其中JSON樹是其提供的一個(gè)非常實(shí)用的功能。JSON樹可以在前端輕松地實(shí)現(xiàn)數(shù)據(jù)的分類、查找和展示。
使用Dojo實(shí)現(xiàn)JSON樹非常簡單,只需要幾個(gè)步驟:
//引入dojo的tree模塊
require(["dojo/store/Memory", "dojo/store/Observable", "dojo/store/JsonRest", "dojo/json", "dojo/tree/ObjectStoreModel",
"dijit/Tree", "dojo/domReady!"],
function(Memory, Observable, JsonRest, json, ObjectStoreModel, Tree){
//1.構(gòu)建store
var restStore = new JsonRest({target: "http://yourserver/rest/"});
var memoryStore = new Observable(new Memory({ idProperty: "id" }));
//2.加載數(shù)據(jù)
restStore.query({parentId:null}).then(function(data){
memoryStore.setData(data);
});
//3.轉(zhuǎn)換成dojo所需的model
var model = new ObjectStoreModel({
store: memoryStore,
query: {parentId: null},
labelAttr: "name",
mayHaveChildren: function(item) {
return item.hasChildren;
},
getChildren: function(item, onComplete){
var query = {parentId: item.id};
restStore.query(query).then(function(data){
onComplete(data);
});
}
});
//4.構(gòu)建tree
var tree = new Tree({
model: model
}, "treeDivId");
});
以上代碼中,先引入dojo需要的庫,然后構(gòu)建store,加載數(shù)據(jù),轉(zhuǎn)換成model,最后構(gòu)建tree。值得注意的是,為了使樹有層次結(jié)構(gòu),需要在store的數(shù)據(jù)結(jié)構(gòu)中加入parentId字段。
通過以上代碼,我們可以輕松實(shí)現(xiàn)查找和展示JSON數(shù)據(jù)的功能。相信Dojo的JSON樹會(huì)成為前端開發(fā)的熱門選擇之一。