select_menu_radio.html 4.0 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128
  1. <!DOCTYPE html>
  2. <HTML>
  3. <HEAD>
  4. <TITLE> ZTREE DEMO - radio select menu</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. check: {
  17. enable: true,
  18. chkStyle: "radio",
  19. radioType: "all"
  20. },
  21. view: {
  22. dblClickExpand: false
  23. },
  24. data: {
  25. simpleData: {
  26. enable: true
  27. }
  28. },
  29. callback: {
  30. onClick: onClick,
  31. onCheck: onCheck
  32. }
  33. };
  34. var zNodes =[
  35. {id:1, pId:0, name:"北京"},
  36. {id:2, pId:0, name:"天津"},
  37. {id:3, pId:0, name:"上海"},
  38. {id:6, pId:0, name:"重庆"},
  39. {id:4, pId:0, name:"河北省", open:true, nocheck:true},
  40. {id:41, pId:4, name:"石家庄"},
  41. {id:42, pId:4, name:"保定"},
  42. {id:43, pId:4, name:"邯郸"},
  43. {id:44, pId:4, name:"承德"},
  44. {id:5, pId:0, name:"广东省", open:true, nocheck:true},
  45. {id:51, pId:5, name:"广州"},
  46. {id:52, pId:5, name:"深圳"},
  47. {id:53, pId:5, name:"东莞"},
  48. {id:54, pId:5, name:"佛山"},
  49. {id:6, pId:0, name:"福建省", open:true, nocheck:true},
  50. {id:61, pId:6, name:"福州"},
  51. {id:62, pId:6, name:"厦门"},
  52. {id:63, pId:6, name:"泉州"},
  53. {id:64, pId:6, name:"三明"}
  54. ];
  55. function onClick(e, treeId, treeNode) {
  56. var zTree = $.fn.zTree.getZTreeObj("treeDemo");
  57. zTree.checkNode(treeNode, !treeNode.checked, null, true);
  58. return false;
  59. }
  60. function onCheck(e, treeId, treeNode) {
  61. var zTree = $.fn.zTree.getZTreeObj("treeDemo"),
  62. nodes = zTree.getCheckedNodes(true),
  63. v = "";
  64. for (var i=0, l=nodes.length; i<l; i++) {
  65. v += nodes[i].name + ",";
  66. }
  67. if (v.length > 0 ) v = v.substring(0, v.length-1);
  68. var cityObj = $("#citySel");
  69. cityObj.attr("value", v);
  70. }
  71. function showMenu() {
  72. var cityObj = $("#citySel");
  73. var cityOffset = $("#citySel").offset();
  74. $("#menuContent").css({left:cityOffset.left + "px", top:cityOffset.top + cityObj.outerHeight() + "px"}).slideDown("fast");
  75. $("body").bind("mousedown", onBodyDown);
  76. }
  77. function hideMenu() {
  78. $("#menuContent").fadeOut("fast");
  79. $("body").unbind("mousedown", onBodyDown);
  80. }
  81. function onBodyDown(event) {
  82. if (!(event.target.id == "menuBtn" || event.target.id == "citySel" || event.target.id == "menuContent" || $(event.target).parents("#menuContent").length>0)) {
  83. hideMenu();
  84. }
  85. }
  86. $(document).ready(function(){
  87. $.fn.zTree.init($("#treeDemo"), setting, zNodes);
  88. });
  89. //-->
  90. </SCRIPT>
  91. <style type="text/css">
  92. </style>
  93. </HEAD>
  94. <BODY>
  95. <h1>带 radio 的单选下拉菜单 -- zTree</h1>
  96. <h6>[ 文件路径: super/select_menu_radio.html ]</h6>
  97. <div class="content_wrap">
  98. <div class="zTreeDemoBackground left">
  99. <ul class="list">
  100. <li class="title">&nbsp;&nbsp;<span class="highlight_red">勾选 radio 或者 点击节点 进行选择</span></li>
  101. <li class="title">&nbsp;&nbsp;Test: <input id="citySel" type="text" readonly value="" style="width:120px;" onclick="showMenu();" />
  102. &nbsp;<a id="menuBtn" href="#" onclick="showMenu(); return false;">select</a></li>
  103. </ul>
  104. </div>
  105. <div class="right">
  106. <ul class="info">
  107. <li class="title"><h2>实现方法说明</h2>
  108. <ul class="list">
  109. <li>用 radio 也可以轻松实现单选的下拉菜单</li>
  110. <li>单选其实没有必要使用 radio, 此 Demo 主要用于 和 其他下拉菜单进行对比</li>
  111. </ul>
  112. </li>
  113. </ul>
  114. </div>
  115. </div>
  116. <div id="menuContent" class="menuContent" style="display:none; position: absolute;">
  117. <ul id="treeDemo" class="ztree" style="margin-top:0; width:180px; height: 300px;"></ul>
  118. </div>
  119. </BODY>
  120. </HTML>