async_edit.html 4.4 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125
  1. <!DOCTYPE html>
  2. <HTML>
  3. <HEAD>
  4. <TITLE> ZTREE DEMO - async & edit</TITLE>
  5. <meta http-equiv="content-type" content="text/html; charset=UTF-8">
  6. <link rel="stylesheet" href="../../../css/demo.css" type="text/css">
  7. <link rel="stylesheet" href="../../../css/zTreeStyle/zTreeStyle.css" type="text/css">
  8. <script type="text/javascript" src="../../../js/jquery.min.js"></script>
  9. <!-- <script type="text/javascript" src="../../../js/jquery-1.4.4.min.js"></script>-->
  10. <script type="text/javascript" src="../../../js/jquery.ztree.core.js"></script>
  11. <script type="text/javascript" src="../../../js/jquery.ztree.excheck.js"></script>
  12. <script type="text/javascript" src="../../../js/jquery.ztree.exedit.js"></script>
  13. <SCRIPT type="text/javascript">
  14. <!--
  15. var setting = {
  16. async: {
  17. enable: true,
  18. url:"../asyncData/getNodes.php",
  19. autoParam:["id", "name=n", "level=lv"],
  20. otherParam:{"otherParam":"zTreeAsyncTest"},
  21. dataFilter: filter
  22. },
  23. view: {expandSpeed:"",
  24. addHoverDom: addHoverDom,
  25. removeHoverDom: removeHoverDom,
  26. selectedMulti: false
  27. },
  28. edit: {
  29. enable: true
  30. },
  31. data: {
  32. simpleData: {
  33. enable: true
  34. }
  35. },
  36. callback: {
  37. beforeRemove: beforeRemove,
  38. beforeRename: beforeRename
  39. }
  40. };
  41. function filter(treeId, parentNode, childNodes) {
  42. if (!childNodes) return null;
  43. for (var i=0, l=childNodes.length; i<l; i++) {
  44. childNodes[i].name = childNodes[i].name.replace(/\.n/g, '.');
  45. }
  46. return childNodes;
  47. }
  48. function beforeRemove(treeId, treeNode) {
  49. var zTree = $.fn.zTree.getZTreeObj("treeDemo");
  50. zTree.selectNode(treeNode);
  51. return confirm("确认删除 节点 -- " + treeNode.name + " 吗?");
  52. }
  53. function beforeRename(treeId, treeNode, newName) {
  54. if (newName.length == 0) {
  55. setTimeout(function() {
  56. var zTree = $.fn.zTree.getZTreeObj("treeDemo");
  57. zTree.cancelEditName();
  58. alert("节点名称不能为空.");
  59. }, 0);
  60. return false;
  61. }
  62. return true;
  63. }
  64. var newCount = 1;
  65. function addHoverDom(treeId, treeNode) {
  66. var sObj = $("#" + treeNode.tId + "_span");
  67. if (treeNode.editNameFlag || $("#addBtn_"+treeNode.tId).length>0) return;
  68. var addStr = "<span class='button add' id='addBtn_" + treeNode.tId
  69. + "' title='add node' onfocus='this.blur();'></span>";
  70. sObj.after(addStr);
  71. var btn = $("#addBtn_"+treeNode.tId);
  72. if (btn) btn.bind("click", function(){
  73. var zTree = $.fn.zTree.getZTreeObj("treeDemo");
  74. zTree.addNodes(treeNode, {id:(100 + newCount), pId:treeNode.id, name:"new node" + (newCount++)});
  75. return false;
  76. });
  77. };
  78. function removeHoverDom(treeId, treeNode) {
  79. $("#addBtn_"+treeNode.tId).unbind().remove();
  80. };
  81. $(document).ready(function(){
  82. $.fn.zTree.init($("#treeDemo"), setting);
  83. });
  84. //-->
  85. </SCRIPT>
  86. <style type="text/css">
  87. .ztree li span.button.add {margin-left:2px; margin-right: -1px; background-position:-144px 0; vertical-align:top; *vertical-align:middle}
  88. </style>
  89. </HEAD>
  90. <BODY>
  91. <h1>异步加载 & 编辑功能 共存</h1>
  92. <h6>[ 文件路径: exedit/async_edit.html ]</h6>
  93. <div class="content_wrap">
  94. <div class="zTreeDemoBackground left">
  95. <ul id="treeDemo" class="ztree"></ul>
  96. </div>
  97. <div class="right">
  98. <ul class="info">
  99. <li class="title"><h2>1、异步加载 & 编辑功能 共存说明</h2>
  100. <ul class="list">
  101. <li>1)、此 Demo 是基于 "高级 增 / 删 / 改 节点" 修改的,并且开放了拖拽功能,可与其进行对比</li>
  102. <li>2)、只需要同时开启编辑模式和异步加载模式即可实现共存</li>
  103. <li class="highlight_red">3)、zTree 完善了异步加载模式下的编辑功能,对于未加载子节点的父节点,增加子节点时,会首先进行异步加载。</li>
  104. </ul>
  105. </li>
  106. <li class="title"><h2>2、setting 配置信息说明</h2>
  107. <ul class="list">
  108. <li class="highlight_red">1)、使用 编辑功能,请参考 "拖拽节点基本控制" 和 "基本 增 / 删 / 改 节点" Demo 中关于 setting 的配置要求</li>
  109. <li class="highlight_red">2)、使用 异步加载功能,请参考 "异步加载 节点数据" Demo 中关于 setting 的配置要求</li>
  110. </ul>
  111. </li>
  112. <li class="title"><h2>3、treeNode 节点数据说明</h2>
  113. <ul class="list">
  114. <li>两种模式共存,对数据无特殊要求,请分别参考 "异步加载 节点数据" & "拖拽 节点 基本控制" & "基本 增 / 删 / 改 节点" 中的相关说明</li>
  115. </ul>
  116. </li>
  117. </ul>
  118. </div>
  119. </div>
  120. </BODY>
  121. </HTML>