jQuery ajax级联二级菜单

需求:

产品营销型网站

上传产品时,有产品种类的选择项,产品种类有一级分类和二级分类,

点击一级分类时,相应显示二级分类的条目。

功能实现:

默认查出一级分类的第一条数据,和一级分类第一条对应的二级分类条目,当选择一级分类的其他条目时,通过ajax查询出数据库中对应的二级分类条目,返回json格式的数据,并显示在二级分类的下拉列表中。

编程实现:

前端页面jsp:

<form method="post" modelAttribute="_pro" name="form1" id="form1" action="${ctx}/product-manage/add-product">
      <table width="100%" border="1" align="center" cellpadding="6" cellspacing="0" bordercolor="#FFFFFF" bgcolor="#F7F7F7">
        <tr>
          <td width="15%" bgcolor="#F7F7F7"><div align="center">产品分类</div></td>
          <td bgcolor="#F7F7F7">
          <select name="pid" id="pid" οnchange="getData()">
          <c:forEach var="data" items="${clist}">
          <option value="${data.id}">${data.name}</option>
          </c:forEach>
          </select>
          &nbsp;&nbsp;
          <select name="categoryId" id="categoryId">
          <c:forEach var="data" items="${slist}">
          <option value="${data.id}">${data.name}</option>
          </c:forEach>
          </select>
          </td>
        </tr>
</form>

 jsp中的ajax的js部分: 

<script src="${ctx}/js/jquery-1.7.1.min.js"></script>
    function getData()
    {
		var pid = $("#pid").val();
	 	$.ajax({        
	         url:"${ctx}/product-manage/sub-category?"+Math.random(),
	         data:{pid : pid},
	         type : "post",  
		 	 cache : false,  
		 	 dataType : "json", 
	         error:function(){
	         	alert("error occured!!!");
	         },
	         success:function(data){
	         if(data!="0"){
				var categoryId = document.getElementById('categoryId');
				//清空数组
				categoryId.length = 0;
				for(var i=0;i<data.length;i++){
					 var xValue=data[i].id;  
                     var xText=data[i].name;  
                     var option=new Option(xText,xValue);  
                     categoryId.add(option);  
				}
	          }else{
	          	 var categoryId = document.getElementById('categoryId');
	          	 categoryId.length = 0;
		      }
	       }
	   });
	}

 后端的json处理代码:

	/**
	 * 得到产品种类对应的子种类  : json数据
	 * @throws IOException
	 */
	@SuppressWarnings("unchecked")
	@RequestMapping(value="sub-category")
	public String getSubCategory(HttpServletRequest request, HttpServletResponse response) throws IOException{
		response.setContentType("text/xml;charset=UTF-8");  
        
	    PrintWriter out = null;  
	    try {
	        out = response.getWriter();  
	    } catch (IOException e) {  
	        e.printStackTrace();  
	    }
	    String pid = request.getParameter("pid");
	    
	    String sql = "select id,name from product_category where pid=?";
		List<ProductCategory> clist = (List<ProductCategory>) DBHandler.queryBeanList(sql, ProductCategory.class, pid);
		
		JSONArray array = new JSONArray();  
        JSONObject member = null;  
        try {
	        for (ProductCategory p:clist) {  
	            member = new JSONObject();  
				member.put("name", p.getName());
	            member.put("id", p.getId());  
	            array.put(member);
	        }
        } catch (JSONException e) {
			e.printStackTrace();
		}
        
        out.print(array.toString());
		
	    return null;
	}

 

 

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
三级级联下拉菜单可以通过Jquery+Ajax实现,以下是一个简单的示例代码: HTML代码: ```html <select id="province"> <option value="">请选择省份</option> <option value="北京">北京</option> <option value="上海">上海</option> <option value="广东">广东</option> </select> <select id="city"> <option value="">请选择城市</option> </select> <select id="district"> <option value="">请选择区县</option> </select> ``` Jquery+Ajax代码: ```javascript $(document).ready(function() { // 加载省份列表 $.ajax({ type: "GET", url: "province.php", success: function(data) { $("#province").append(data); } }); // 省份选项改变时,加载城市列表 $("#province").change(function() { var province = $(this).val(); $("#city").html("<option value=''>请选择城市</option>"); $("#district").html("<option value=''>请选择区县</option>"); if (province != "") { $.ajax({ type: "GET", url: "city.php", data: {"province": province}, success: function(data) { $("#city").append(data); } }); } }); // 城市选项改变时,加载区县列表 $("#city").change(function() { var province = $("#province").val(); var city = $(this).val(); $("#district").html("<option value=''>请选择区县</option>"); if (city != "") { $.ajax({ type: "GET", url: "district.php", data: {"province": province, "city": city}, success: function(data) { $("#district").append(data); } }); } }); }); ``` 在省份、城市、区县列表对应的php文件中,需要根据传入的参数返回对应的选项列表。例如,city.php文件可能如下所示: ```php $province = $_GET["province"]; echo "<option value=''>请选择城市</option>"; if ($province == "北京") { echo "<option value='北京市'>北京市</option>"; } else if ($province == "上海") { echo "<option value='上海市'>上海市</option>"; } else if ($province == "广东") { echo "<option value='广州市'>广州市</option>"; echo "<option value='深圳市'>深圳市</option>"; echo "<option value='珠海市'>珠海市</option>"; } ``` 类似地,district.php文件也需要根据传入的参数返回对应的选项列表。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值