page.html 5.9 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151
  1. <!DOCTYPE html>
  2. <HTML>
  3. <HEAD>
  4. <TITLE> ZTREE DEMO - big data page</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: getUrl
  19. },
  20. check: {
  21. enable: true
  22. },
  23. data: {
  24. simpleData: {
  25. enable: true
  26. }
  27. },
  28. view: {
  29. addDiyDom: addDiyDom
  30. },
  31. callback: {
  32. beforeExpand: beforeExpand,
  33. onAsyncSuccess: onAsyncSuccess,
  34. onAsyncError: onAsyncError
  35. }
  36. };
  37. var zNodes =[
  38. {name:"分页测试", t:"请点击分页按钮", id:"1", count:2000, page:0, pageSize:100, isParent:true}
  39. ];
  40. var curPage = 0;
  41. function getUrl(treeId, treeNode) {
  42. var param = "id="+ treeNode.id +"_"+treeNode.page +"&count="+treeNode.pageSize,
  43. aObj = $("#" + treeNode.tId + "_a");
  44. aObj.attr("title", "当前第 " + treeNode.page + " 页 / 共 " + treeNode.maxPage + " 页")
  45. return "../asyncData/getNodesForBigData.php?" + param;
  46. }
  47. function goPage(treeNode, page) {
  48. treeNode.page = page;
  49. if (treeNode.page<1) treeNode.page = 1;
  50. if (treeNode.page>treeNode.maxPage) treeNode.page = treeNode.maxPage;
  51. if (curPage == treeNode.page) return;
  52. curPage = treeNode.page;
  53. var zTree = $.fn.zTree.getZTreeObj("treeDemo");
  54. zTree.reAsyncChildNodes(treeNode, "refresh");
  55. }
  56. function beforeExpand(treeId, treeNode) {
  57. if (treeNode.page == 0) treeNode.page = 1;
  58. return !treeNode.isAjaxing;
  59. }
  60. function onAsyncSuccess(event, treeId, treeNode, msg) {
  61. }
  62. function onAsyncError(event, treeId, treeNode, XMLHttpRequest, textStatus, errorThrown) {
  63. var zTree = $.fn.zTree.getZTreeObj("treeDemo");
  64. alert("异步获取数据出现异常。");
  65. treeNode.icon = "";
  66. zTree.updateNode(treeNode);
  67. }
  68. function addDiyDom(treeId, treeNode) {
  69. if (treeNode.level>0) return;
  70. var aObj = $("#" + treeNode.tId + "_a");
  71. if ($("#addBtn_"+treeNode.id).length>0) return;
  72. var addStr = "<span class='button lastPage' id='lastBtn_" + treeNode.id
  73. + "' title='last page' onfocus='this.blur();'></span><span class='button nextPage' id='nextBtn_" + treeNode.id
  74. + "' title='next page' onfocus='this.blur();'></span><span class='button prevPage' id='prevBtn_" + treeNode.id
  75. + "' title='prev page' onfocus='this.blur();'></span><span class='button firstPage' id='firstBtn_" + treeNode.id
  76. + "' title='first page' onfocus='this.blur();'></span>";
  77. aObj.after(addStr);
  78. var first = $("#firstBtn_"+treeNode.id);
  79. var prev = $("#prevBtn_"+treeNode.id);
  80. var next = $("#nextBtn_"+treeNode.id);
  81. var last = $("#lastBtn_"+treeNode.id);
  82. treeNode.maxPage = Math.round(treeNode.count/treeNode.pageSize - .5) + (treeNode.count%treeNode.pageSize == 0 ? 0:1);
  83. first.bind("click", function(){
  84. if (!treeNode.isAjaxing) {
  85. goPage(treeNode, 1);
  86. }
  87. });
  88. last.bind("click", function(){
  89. if (!treeNode.isAjaxing) {
  90. goPage(treeNode, treeNode.maxPage);
  91. }
  92. });
  93. prev.bind("click", function(){
  94. if (!treeNode.isAjaxing) {
  95. goPage(treeNode, treeNode.page-1);
  96. }
  97. });
  98. next.bind("click", function(){
  99. if (!treeNode.isAjaxing) {
  100. goPage(treeNode, treeNode.page+1);
  101. }
  102. });
  103. };
  104. $(document).ready(function(){
  105. $.fn.zTree.init($("#treeDemo"), setting, zNodes);
  106. });
  107. //-->
  108. </SCRIPT>
  109. <style type="text/css">
  110. .ztree li span.button.firstPage {float:right; margin-left:2px; margin-right: 0; background-position:-144px -16px; vertical-align:top; *vertical-align:middle}
  111. .ztree li span.button.prevPage {float:right; margin-left:2px; margin-right: 0; background-position:-144px -48px; vertical-align:top; *vertical-align:middle}
  112. .ztree li span.button.nextPage {float:right; margin-left:2px; margin-right: 0; background-position:-144px -64px; vertical-align:top; *vertical-align:middle}
  113. .ztree li span.button.lastPage {float:right; margin-left:2px; margin-right: 0; background-position:-144px -32px; vertical-align:top; *vertical-align:middle}
  114. </style>
  115. </HEAD>
  116. <BODY>
  117. <h1>分页加载大数据量</h1>
  118. <h6>[ 文件路径: bigdata/page.html ]</h6>
  119. <div class="content_wrap">
  120. <div class="zTreeDemoBackground left">
  121. <ul id="treeDemo" class="ztree"></ul>
  122. </div>
  123. <div class="right">
  124. <ul class="info">
  125. <li class="title"><h2>1、大数据量加载说明</h2>
  126. <ul class="list">
  127. <li>1)、分页方案可以有效解决某一级节点数据超大的情况。</li>
  128. <li>2)、分页按钮通过自定义控件的方法实现。</li>
  129. <li class="highlight_red">3)、分页方案对于 checkbox 的关联关系无能为力,只能每次翻页后进行修正。由于时间关系,Demo 中不对 checkbox 的关联进行任何修正处理。</li>
  130. <li class="highlight_red">4)、分页方案中,从 zTree 得到的节点数据只有当前页的节点数据,可以在每次翻页后自行保存每页的数据,作为缓存,具体情况要根据实际需求来决定。</li>
  131. </li>
  132. <li class="title"><h2>2、setting 配置信息说明</h2>
  133. <ul class="list">
  134. <li>需要设置 setting.async 异步加载部分的参数</li>
  135. <li>其他不需要进行特殊的配置,根据自己的需求自行设置</li>
  136. </ul>
  137. </li>
  138. <li class="title"><h2>3、treeNode 节点数据说明</h2>
  139. <ul class="list">
  140. <li>对 节点数据 没有特殊要求,用户可以根据自己的需求添加自定义属性</li>
  141. </ul>
  142. </li>
  143. </ul>
  144. </div>
  145. </div>
  146. </BODY>
  147. </HTML>