java二级级联菜单_【JavaWeb】实现二级联动菜单

实现效果

%E4%BA%8C%E7%BA%A7%E8%81%94%E5%8A%A8%E8%8F%9C%E5%8D%95%E6%95%88%E6%9E%9C.gif

频道信息

package demo;

public class Channel {

private String code; //频道编码

private String name; //频道名称

public Channel() {

}

public Channel(String code, String name) {

super();

this.code = code;

this.name = name;

}

public String getCode() {

return code;

}

public void setCode(String code) {

this.code = code;

}

public String getName() {

return name;

}

public void setName(String name) {

this.name = name;

}

}

Servlet提供数据

package demo;

import java.io.IOException;

import java.util.ArrayList;

import java.util.List;

import javax.servlet.ServletException;

import javax.servlet.annotation.WebServlet;

import javax.servlet.http.HttpServlet;

import javax.servlet.http.HttpServletRequest;

import javax.servlet.http.HttpServletResponse;

import com.alibaba.fastjson.JSON;

/**

* Servlet implementation class ChannelServlet

*/

@WebServlet("/ch_content")

public class ChannelServlet extends HttpServlet {

private static final long serialVersionUID = 1L;

/**

* @see HttpServlet#HttpServlet()

*/

public ChannelServlet() {

super();

// TODO Auto-generated constructor stub

}

/**

* @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response)

*/

protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException {

String level = request.getParameter("level"); //获取频道,1为父类频道,2为子类频道

String parent = request.getParameter("parent"); //获取父类频道code,以便于加载子类频道信息

List chlist = new ArrayList<>();

if(level.equals("1")) {

chlist.add(new Channel("ai", "前沿/区块链/人工智能"));

chlist.add(new Channel("web", "前端/小程序/js"));

}else if(level.equals("2")) {

if(parent.equals("ai")) {

chlist.add(new Channel("micro", "微服务"));

chlist.add(new Channel("blockchain", "区块链"));

chlist.add(new Channel("other", "..."));

}else if(parent.equals("web")) {

chlist.add(new Channel("html", "HTML"));

chlist.add(new Channel("css", "CSS"));

chlist.add(new Channel("other", "..."));

}

}

String json = JSON.toJSONString(chlist);

response.setContentType("text/html;charset=utf-8");

response.getWriter().println(json);

}

}

Ajax请求数据

Insert title here

//获取父类频道的数据

$(function(){

$.ajax({

"url" : "/ajax/ch_content",

"type" : "get",

"data" : {"level" : "1"},

"dataType" : "json",

"success" : function(json){

var html = "";

for(var i = 0; i < json.length; i++){

html += "" + json[i].name + "";

}

$("#lv1").append(html);

}

})

})

//联动子类频道的数据

$(function(){

$("#lv1").change(function(){

var parent = $(this).val(); //获取当前选项的value值

$.ajax({

"url" : "/ajax/ch_content",

"type" : "get",

"data" : {"level" : "2", "parent" : parent},

"dataType" : "json",

"success" : function(json){

var html = "";

$("#lv2>option").remove();

for(var i = 0; i < json.length; i++){

html += "" + json[i].name + "";

}

$("#lv2").append(html);

}

})

})

})

请输入

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
市区二级级联通常是在表单中选择地址时使用的,我们可以通过在Java中使用JSP或Servlet实现市区二级级联。 首先,我们需要在JSP页面中使用HTML表单来实现市区二级级联,例如: ```html <form action="submit-form.jsp" method="post"> <select name="province" id="province"> <option value="">请选择省份</option> <option value="北京市">北京市</option> <option value="上海市">上海市</option> <option value="广东省">广东省</option> <!-- 其他省份省略 --> </select> <select name="city" id="city"> <option value="">请选择城市</option> </select> <input type="submit" value="提交"> </form> ``` 在这个表单中,我们使用了两个下拉框,一个用于选择省份,一个用于选择城市。初始时,城市下拉框中没有任何选项。当用户选择省份后,我们需要使用Ajax技术动态加载该省份下的城市表,并将其添加到城市下拉框中。 接下来,我们需要在JavaScript中实现这个动态加载城市表的功能。例如: ```javascript $(function() { // 当省份下拉框选项变化时 $('#province').change(function() { // 获取选中的省份名称 var provinceName = $(this).val(); // 如果省份名称为空,清空城市下拉框 if (provinceName == '') { $('#city').empty(); return; } // 向服务器发送Ajax请求,获取该省份下的城市表 $.ajax({ url: 'get-cities.jsp', type: 'post', data: { province: provinceName }, success: function(data) { // 将城市表添加到城市下拉框中 $('#city').empty(); $.each(data, function(i, city) { $('#city').append('<option value="' + city + '">' + city + '</option>'); }); } }); }); }); ``` 在这个JavaScript代码中,我们使用了jQuery库来简化操作。当省份下拉框选项变化时,我们首先获取选中的省份名称,如果名称为空,则清空城市下拉框。否则,向服务器发送Ajax请求,获取该省份下的城市表,并将其添加到城市下拉框中。 最后,我们需要在服务器端实现get-cities.jsp页面,用于返回该省份下的城市表。例如: ```java <%@ page contentType="application/json;charset=UTF-8" %> <% // 获取选中的省份名称 String provinceName = request.getParameter("province"); // 查询该省份下的城市表 String[] cityList = getCityList(provinceName); // 将城市表转换为Json格式并输出 out.print(new Gson().toJson(cityList)); %> ``` 在这个JSP页面中,我们首先获取选中的省份名称,然后调用getCityList方法来查询该省份下的城市表。最后,我们使用Gson库将城市表转换为Json格式并输出。 至此,我们就完成了Java实现市区二级级联的过程。需要注意的是,这只是一个简单的例子,实际应用中可能需要更多的代码来实现更复杂的功能。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值