后台实现可以参考我以前发表的文章 地区三级联动

zTree API js 下载 点击打开链接

一个效果demo


<!DOCTYPE html>
<HTML>
<HEAD>
	<TITLE> ZTREE DEMO - select menu</TITLE>
	<meta http-equiv="content-type" content="text/html; charset=UTF-8">
	<link rel="stylesheet" href="js/ztree/css/demo.css" type="text/css">
	<link rel="stylesheet" href="js/ztree/css/zTreeStyle/zTreeStyle.css" type="text/css">
	<script type="text/javascript" src="js/ztree/js/jquery-1.4.4.min.js"></script>
	<script type="text/javascript" src="js/ztree/js/jquery.ztree.core-3.5.js"></script>
	<!--  <script type="text/javascript" src="../../../js/jquery.ztree.excheck-3.5.js"></script>
	  <script type="text/javascript" src="../../../js/jquery.ztree.exedit-3.5.js"></script>-->
	<SCRIPT type="text/javascript">
		
		var setting = {
		    async: {
				enable: true,
				url:"/area/getAreas.do",
				autoParam:["id=code"],
				//autoParam:["id", "name=n", "level=lv"],
				//otherParam:{"otherParam":"zTreeAsyncTest"},
				//dataFilter: filter,
				type: "get"
			},
			view: {
				dblClickExpand: false
			},
			data: {
				simpleData: {
					enable: true
				}
			},
			callback: {
				beforeClick: beforeClick,
				onClick: onClick
			}
		};

		var zNodes;

		function beforeClick(treeId, treeNode) {
			//var check = (treeNode && !treeNode.isParent);
			//if (!check) alert("只能选择城市...");
			return true;
		}
		
		function onClick(e, treeId, treeNode) {
			var zTree = $.fn.zTree.getZTreeObj("treeDemo"),
			nodes = zTree.getSelectedNodes(),
			v = "";
			var code="";
			nodes.sort(function compare(a,b){return a.id-b.id;});
			for (var i=0, l=nodes.length; i<l; i++) {
				//v += nodes[i].name + ",";
				v = nodes[i].name;
				code=nodes[i].id;
			}
			if (v.length > 0 ) v = v.substring(0, v.length);//-1
			var cityObj = $("#citySel");
			cityObj.attr("value", v);
			$("#areaCodeV").val(code);
		}

		//选 择
		function showMenu() {
			var cityObj = $("#citySel");
			var cityOffset = $("#citySel").offset();
			$("#menuContent").css({left:cityOffset.left + "px", top:cityOffset.top + cityObj.outerHeight() + "px"}).slideDown("fast");

			$("body").bind("mousedown", onBodyDown);
		}
		function hideMenu() {
			$("#menuContent").fadeOut("fast");
			$("body").unbind("mousedown", onBodyDown);
		}
		function onBodyDown(event) {
			if (!(event.target.id == "menuBtn" || event.target.id == "menuContent" || $(event.target).parents("#menuContent").length>0)) {
				hideMenu();
			}
		}

		$(document).ready(function(){
			
			$.ajax({
				url : "/area/getAreas.do",
				type : "POST",
				dataType : "json",
				data : {
					code : "P"
				},
				success : function(returnData, status) {
					if (status = "success") {
						//alert("returnData:"+returnData);
						 zNodes = returnData;
						//zNodes=dataj;
						$.fn.zTree.init($("#treeDemo"), setting, zNodes);
					}
				}
			});
			
			
			//alert(JSON.stringify(zNodes));
			//$.fn.zTree.init($("#treeDemo"), setting, zNodes);
		});
		
		//通过等级获取了菜单 , seleId
		function getAreas(level) {
			var dataj;
			$.ajax({
				url : "/area/getAreas.do",
				type : "POST",
				dataType : "json",
				data : {
					code : level
				},
				success : function(returnData, status) {
					if (status = "success") {
						alert("returnData:"+returnData);
						var dataj = returnData;
						zNodes=dataj;
					}
				}
			});
			
			return dataj;
		}
		
	</SCRIPT>
	<style type="text/css">
	</style>
 </HEAD>

<BODY>
<h1>下拉菜单</h1>
<h6>[ 文件路径: super/select_menu.html ]</h6>
<div class="content_wrap">
	<div class="zTreeDemoBackground left">
		<ul class="list">
			<li class="title"><span class="highlight_red">
			选择城市时,按下 Ctrl 或 Cmd 键可以进行多选</span></li>
			
			<li class="title">城市:
			<input id="citySel" type="text" readonly value="" style="width:120px;"/>
			<input id="areaCodeV" type="hidden" >
		
		<a id="menuBtn" href="#" onclick="showMenu(); return false;">选择</a>
		
		</li>
		</ul>
	</div>
	<div class="right">
		<ul class="info">
			<li class="title"><h2>实现方法说明</h2>
				<ul class="list">
				<li>用 zTree 实现这种下拉菜单,应该说是比较容易的,你只需要控制 zTree 所在容器的隐藏/显示,以及位置即可。</li>
				<li class="highlight_red">zTree v3.x 实现了多点选中功能,因此对于需要多选的下拉菜单也易如反掌。</li>
				<li class="highlight_red">利用 setting 的各项配置参数,完全可以满足大部分的功能需求。</li>
				</ul>
			</li>
		</ul>
	</div>
</div>

<div id="menuContent" class="menuContent" style="display:none; position: absolute;">
	
	<ul id="treeDemo" class="ztree" style="margin-top:0; width:160px;"></ul>
	
	
</div>
<input type="button" id="clickVal" />
<script type="text/javascript">

$(function(){
	
	$("#clickVal").click(function()
			{
		        var vv=$("#citySel").val();
		        var code=$("#areaCodeV").val();
		        alert(vv+","+code);
			});
	
})
</script>

</BODY>
</HTML>

实际应用中代码


<!-- 	<link rel="stylesheet" href="js/ztree/css/demo.css" type="text/css"> -->
	<link rel="stylesheet" href="js/ztree/css/zTreeStyle/zTreeStyle.css" type="text/css">
<!-- 	<script type="text/javascript" src="js/ztree/js/jquery-1.4.4.min.js"></script> -->
	<script type="text/javascript" src="js/ztree/js/jquery.ztree.core-3.5.js"></script>
	<script src="js/util/area.js" type="text/javascript"></script>


地区:
		
		<input id="citySel" type="text" readonly value="" style="width:120px;" onclick="showMenu(); return false;"/>
		<input id="areaCodeV" type="hidden" >
		
		<div id="menuContent" class="menuContent" style="display:none; position: absolute; background:rgb(194, 220, 237);height:500px;OVERFLOW-Y: auto; OVERFLOW-X:hidden; ">
	      <a href="javascript:claclArea()">清空</a>
	       <ul id="treeDemo" class="ztree" style="margin-top:0; width:160px;"></ul>
	       
        </div>
		

		var setting = {
		    async: {
				enable: true,
				url:"/area/getAreas.do",
				autoParam:["id=code"],
				//autoParam:["id", "name=n", "level=lv"],
				//otherParam:{"otherParam":"zTreeAsyncTest"},
				//dataFilter: filter,
				type: "get"
			},
			view: {
				dblClickExpand: false
			},
			data: {
				simpleData: {
					enable: true
				}
			},
			callback: {
				beforeClick: beforeClick,
				onClick: onClick
			}
		};

		var zNodes;

		function beforeClick(treeId, treeNode) {
			//var check = (treeNode && !treeNode.isParent);
			//if (!check) alert("只能选择城市...");
			return true;
		}
		
		function onClick(e, treeId, treeNode) {
			var zTree = $.fn.zTree.getZTreeObj("treeDemo"),
			nodes = zTree.getSelectedNodes(),
			v = "";
			var code="";
			nodes.sort(function compare(a,b){return a.id-b.id;});
			for (var i=0, l=nodes.length; i<l; i++) {
				//v += nodes[i].name + ",";
				v = nodes[i].name;
				code=nodes[i].id;
			}
			if (v.length > 0 ) v = v.substring(0, v.length);//-1
			var cityObj = $("#citySel");
			cityObj.attr("value", v);
			$("#areaCodeV").val(code);
		}

		//选 择
		function showMenu() {
			var cityObj = $("#citySel");
			var cityOffset = $("#citySel").offset();
			$("#menuContent").css({left:cityOffset.left + "px", top:cityOffset.top + cityObj.outerHeight() + "px"}).slideDown("fast");

			$("body").bind("mousedown", onBodyDown);
		}
		function hideMenu() {
			$("#menuContent").fadeOut("fast");
			$("body").unbind("mousedown", onBodyDown);
		}
		function onBodyDown(event) {
			if (!(event.target.id == "menuBtn" || event.target.id == "menuContent" || $(event.target).parents("#menuContent").length>0)) {
				hideMenu();
			}
		}

		$(document).ready(function(){
			
			$.ajax({
				url : "/area/getAreas.do",
				type : "POST",
				dataType : "json",
				data : {
					code : "P"
				},
				success : function(returnData, status) {
					if (status = "success") {
						//alert("returnData:"+returnData);
						 zNodes = returnData;
						//zNodes=dataj;
						$.fn.zTree.init($("#treeDemo"), setting, zNodes);
					}
				}
			});
			
			
			//alert(JSON.stringify(zNodes));
			//$.fn.zTree.init($("#treeDemo"), setting, zNodes);
		});
		
		//通过等级获取了菜单 , seleId
		function getAreas(level) {
			var dataj;
			$.ajax({
				url : "/area/getAreas.do",
				type : "POST",
				dataType : "json",
				data : {
					code : level
				},
				success : function(returnData, status) {
					if (status = "success") {
						alert("returnData:"+returnData);
						var dataj = returnData;
						zNodes=dataj;
					}
				}
			});
			
			return dataj;
		}
		
		//清空
		function claclArea()
		{
			$("#citySel").val('');
			$("#areaCodeV").val('');
		}


版本2 显示全部地区

		var setting = {
		    async: {
				enable: true,
				url:"/area/getAreas.do",
				autoParam:["id=code"],
				//autoParam:["id", "name=n", "level=lv"],
				//otherParam:{"otherParam":"zTreeAsyncTest"},
				//dataFilter: filter,
				type: "get"
			},
			view: {
				dblClickExpand: false
			},
			data: {
				simpleData: {
					enable: true
				}
			},
			callback: {
				beforeClick: beforeClick,
				onClick: onClick
			}
		};

		var zNodes;

		function beforeClick(treeId, treeNode) {
			//var check = (treeNode && !treeNode.isParent);
			//if (!check) alert("只能选择城市...");
			return true;
		}
		
		function onClick(e, treeId, treeNode) {
			var zTree = $.fn.zTree.getZTreeObj("treeDemo"),
			nodes = zTree.getSelectedNodes(),
			v = "";
			var code="";
			nodes.sort(function compare(a,b){return a.id-b.id;});
			for (var i=0, l=nodes.length; i<l; i++) {
				//v += nodes[i].name + ",";
				v = nodes[i].name;
				code=nodes[i].id;
				var nodeall = nodes[i].getParentNode();
				var check = (nodeall && !nodeall.isParent);
				if (!check)
				{
					v=(nodeall.name+"  ")+v;
					$("#area_h_2").val(nodeall.id);
						var nodeall2 = nodeall.getParentNode();
						if (nodeall2!=null)
				       {
					     v=(nodeall2.name+"  ")+v;
						 $("#area_h_3").val(nodeall2.id);
				       }
					
					
				}
				
				
				
			}
			//if (v.length > 0 ) v = v.substring(0, v.length);//-1
			var cityObj = $("#citySel");
			
			
			
			cityObj.attr("value", v);
			$("#area_h_3").val(code);
		}

		//选 择
		function showMenu() {
			var cityObj = $("#citySel");
			var cityOffset = $("#citySel").offset();
			$("#menuContent").css({left:cityOffset.left + "px", top:cityOffset.top + cityObj.outerHeight() + "px"}).slideDown("fast");

			$("body").bind("mousedown", onBodyDown);
		}
		function hideMenu() {
			$("#menuContent").fadeOut("fast");
			$("body").unbind("mousedown", onBodyDown);
		}
		function onBodyDown(event) {
			if (!(event.target.id == "menuBtn" || event.target.id == "menuContent" || $(event.target).parents("#menuContent").length>0)) {
				hideMenu();
			}
		}

		$(document).ready(function(){
			
			$.ajax({
				url : "/area/getAreas.do",
				type : "POST",
				dataType : "json",
				data : {
					code : "P"
				},
				success : function(returnData, status) {
					if (status = "success") {
						//alert("returnData:"+returnData);
						 zNodes = returnData;
						//zNodes=dataj;
						$.fn.zTree.init($("#treeDemo"), setting, zNodes);
					}
				}
			});
			
			
			//alert(JSON.stringify(zNodes));
			//$.fn.zTree.init($("#treeDemo"), setting, zNodes);
		});
		
		//通过等级获取了菜单 , seleId
		function getAreas(level) {
			var dataj;
			$.ajax({
				url : "/area/getAreas.do",
				type : "POST",
				dataType : "json",
				data : {
					code : level
				},
				success : function(returnData, status) {
					if (status = "success") {
						alert("returnData:"+returnData);
						var dataj = returnData;
						zNodes=dataj;
					}
				}
			});
			
			return dataj;
		}
		
		//清空
		function claclArea()
		{
			$("#citySel").val('');
			$("#areaCodeV").val('');
		}


更多相关文章

  1. 如何在提交后有一个自动更新的下拉菜单?
  2. 在javascript中识别/获取选定的上下文菜单项
  3. 桌面视图中的SlikNav多级菜单?
  4. 根据下拉菜单的选择更改div的内容
  5. bootstrap入门【按钮式下拉菜单,输入框组】
  6. 单击它时,为什么下拉菜单不在我的导航栏中工作?
  7. 无法使用jquery将活动类添加到当前选定的菜单
  8. JQuery的。简单的下拉选择菜单行为问题
  9. 4th,Python三级菜单

随机推荐

  1. 《精通Android 2》书评
  2. Android音频底层调试-基于tinyalsa
  3. android selector的用法解析
  4. Android 超级用户工具箱
  5. 10个很棒的学习Android 开发的网站
  6. Android应用开发工程师项目实战 共18章(
  7. android基础控件学习学习(1)【入门篇】
  8. android里面EditTex多行输入及输入置顶问
  9. Android菜鸟的成长笔记(17)—— 再看Androi
  10. Android 内存泄漏优化汇总