java Ztree异步 实现数据加载

前台代码:

<script type="text/javascript">
var setting = {
data : {
simpleData : {
enable : true
}
}
};


var nTreeNodes;
$(document).ready(function() {
/** 通过异步交互将后台的数据加载到前台*/
jQuery.post(path + "/ztree/initData", {}, function(data) {
nTreeNodes = eval(data);
$.fn.zTree.init($("#treeDemo"), setting, nTreeNodes);
});
});
</script>
</head>
<body>
<div class="Btit1">推荐图谱</div>
<div class="zTreeDemoBackground left">
<ul id="treeDemo" class="ztree"></ul>
</div>
</body>
后台代码:

/**

*传递的参数 当前节点
*/
@RequestMapping("initData")
public void initData(HttpServletRequest request,HttpServletResponse response){
String id=request.getParameter("id")==null?"":request.getParameter("id").toString();
String user_id=request.getSession().getAttribute("user_id").toString();
List<ZtreeEntity> list = null;
list = this.service.initData(user_id,id);
JSONArray jsonArray = new JSONArray();
for (int i = 0; i < list.size(); i++) {
ZtreeEntity rEntity = list.get(i);
JSONObject p_json = new JSONObject();
p_json.put("id", rEntity.getNodeId());
if (null==rEntity.getParentId()) {
p_json.put("pId", "0");
}else {
p_json.put("pId", rEntity.getParentId());
}
p_json.put("name", rEntity.getNodeName());
if (null==rEntity.getParentId()) {
p_json.put("isParent", true);
}
jsonArray.add(p_json);
}
try {
/** 通过string转成json格式 */
response.setContentType("text/html; charset=UTF-8");
response.getWriter().write(jsonArray.toString());
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}

你可能感兴趣的:(java Ztree异步 实现数据加载)