jquery使用EasyUI Tree異步加載JSON數(shù)據(jù)(生成樹)
這幾天因?yàn)楣ぷ餍枰鲆粋€支持無限級的菜單。
我也是菜鳥一只,能想到的東西不多,所以用了Easy UI的tree組件。
不得不說,easyui確實(shí)很強(qiáng)大。
因?yàn)槭菬o限級菜單,數(shù)據(jù)量可能有點(diǎn)大,所以考慮采用異步加載。
但是因?yàn)楹笈_默認(rèn)傳來的數(shù)據(jù)是 一個實(shí)體,所以又在后臺進(jìn)行了JSON字符串拼接。
最后,在網(wǎng)上找了N多代碼,然后又去問了好幾個群里的網(wǎng)友,終于搞出來這個小東西。
一、HTML部分代碼
<div id="categoryChooseDiv" title="請選擇分類"
style="width: 650px; height: 300px;">
<ul id="MyTree"></ul>
</div>
html部分很簡單,只要放一個ul就可以了。
二、JS部分代碼
function showCategory(){
$('#MyTree').tree({
checkbox: false,
url: '/category/getCategorys.java?Id=0',
onBeforeExpand:function(node,param){
$('#MyTree').tree('options').url = "/category/getCategorys.java?Id=" + node.id;
},
onClick:function(node){
var state=node.state;
if(!state){ //判斷當(dāng)前選中的節(jié)點(diǎn)是否為根節(jié)點(diǎn)
currentId=node.id;
$("#chooseOk").attr( "disabled" , false ); //如果為根節(jié)點(diǎn) 則OK按鈕可用
}else{
$("#chooseOk").attr( "disabled" , true ); //如果不為根節(jié)點(diǎn) 則OK按鈕不可用
}
}
});
}
最后幾句代碼是因?yàn)槲疫@個項(xiàng)目需要,只有選擇到最下級節(jié)點(diǎn)的時候,才運(yùn)行點(diǎn)擊“確定”。否則不允許。
當(dāng)用戶點(diǎn)擊確定的時候,需要獲取 當(dāng)前用戶選中節(jié)點(diǎn) 的所有父節(jié)點(diǎn)
var nodes=[]; //定義數(shù)組用來存放各個節(jié)點(diǎn)名稱
var node =$("#MyTree").tree("getSelected"); //當(dāng)前選中節(jié)點(diǎn)
nodes.push(node.text); //首先放入當(dāng)前節(jié)點(diǎn)
var pnode = $('#MyTree').tree('getParent',node.target); //獲取當(dāng)前節(jié)點(diǎn)的父節(jié)點(diǎn)
while(pnode!=null){
nodes.push(pnode.text); //依次放入各個父節(jié)點(diǎn),直到根節(jié)點(diǎn)為止
pnode = $('#MyTree').tree('getParent',pnode.target);
}
nodes.reverse(); //數(shù)組元素倒序排序
$.each(nodes,function(){ //循環(huán)取值
var html=this;
$("#inCategoryDiv").html( $("#inCategoryDiv").html() + html + ">>" );
});
其實(shí),主要問題在于后臺對數(shù)據(jù)的處理,即如何能夠轉(zhuǎn)化為 easyui tree才可以識別的JSON數(shù)據(jù)。
三、后臺代碼(Java)
public ResponseEntity<String> findBy(Integer Id ) {
List<Category> categorys = getcategorys(Id );
String ss="";
ss+="[";
for( Category category : categorys )
{
ss+="{";
//ss += "\"id\": \""+category.getId()+"\",\"text\": \""+category.getName().toString()+"\",\"iconCls\": \"icon-ok\",\"state\": \"closed\"";;
List<Category> cs = getcategorys( category.getId() ); //判斷當(dāng)前節(jié)點(diǎn)是否還有子節(jié)點(diǎn)
if(cs.size()==0){ //沒有子節(jié)點(diǎn) 設(shè)置 state 為空
ss+=String.format("\"id\": \"%s\", \"text\": \"%s\", \"iconCls\": \"\", \"state\": \"\"", category.getId() , category.getName());
}else{ // 還有子節(jié)點(diǎn) 設(shè)置 state為closed
ss+=String.format("\"id\": \"%s\", \"text\": \"%s\", \"iconCls\": \"\", \"state\": \"closed\"", category.getId() , category.getName());
}
ss+="},";
}
ss=ss.substring(0, ss.length() - 1);
ss+="]";
return super.responseString(ss); //字符編碼轉(zhuǎn)換
}
大致一個流程就是前臺傳來ID,然后獲取到實(shí)體對象,然后對實(shí)體進(jìn)行循環(huán),然后進(jìn)行字符串處理這里設(shè)置state的意義主要在于讓 easyui 的tree可以知道當(dāng)前節(jié)點(diǎn)是否為最低級節(jié)點(diǎn),然后在前面顯示不同的圖標(biāo)。
總結(jié):
就是這個小東西,折騰了我好幾天,呵呵,因?yàn)榘程苛?。不過還好最后搞懂了,也理解了很多東西。
以前一直覺得JSON這東西很神秘,現(xiàn)在覺得它還是有規(guī)律的。
使用easyui tree的重點(diǎn)之一,就是對JSON數(shù)據(jù)的處理,有兩種方式可以實(shí)現(xiàn):第一就是使用String的format方法。這個大家可以去網(wǎng)上參考一下相關(guān)的API等等,我第一次寫錯了,字符串的占位符應(yīng)該是 %s 我寫成了 {0} 找了半天,才知道問題所在。 第二種方式,就是我上面注釋掉的那一行,直接使用字符串拼接。
然后上面獲取當(dāng)前節(jié)點(diǎn)的所有父節(jié)點(diǎn)的時候,又糾結(jié)了半天,去網(wǎng)上找了很多代碼,都不能用,最后還是自己想了一招,才得以解決。
優(yōu)點(diǎn):可以使用異步加載,支持無限級。
缺點(diǎn):太繁瑣,對后臺的數(shù)據(jù)格式要求過高。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
jquery獲取一組checkbox的值(實(shí)例代碼)
使用jquery獲取一組checkbox的值實(shí)例代碼。需要的朋友可以過來參考下,希望對大家有所幫助2013-11-11
jquery實(shí)現(xiàn)輸入框?qū)崟r輸入觸發(fā)事件代碼
本文主要分享了jquery實(shí)現(xiàn)輸入框?qū)崟r輸入觸發(fā)事件的代碼,代碼簡單易懂,需要的朋友一起來看下吧2016-12-12
jQuery實(shí)現(xiàn)按鈕的點(diǎn)擊 全選/反選 單選框/復(fù)選框 文本框 表單驗(yàn)證
這篇文章主要介紹了jQuery實(shí)現(xiàn)按鈕的點(diǎn)擊 全選/反選 單選框/復(fù)選框 文本框 表單驗(yàn)證的相關(guān)資料,需要的朋友可以參考下2015-06-06
jQuery 判斷元素是否存在然后按需加載內(nèi)容的實(shí)現(xiàn)代碼
這篇文章主要介紹了jQuery 判斷元素是否存在然后按需加載內(nèi)容的實(shí)現(xiàn)代碼,需要的朋友可以參考下2020-01-01
jQuery 練習(xí)[二] jquery 對象選擇器(1)
根據(jù) id 選擇(通過 id 只能選擇一個對象), 如: $("#div2") ,jquery 對象選擇器是jquery的一個亮點(diǎn)。2010-05-05

