web项目的菜单展示-三级联动菜单展示

2024-06-14 16:20

本文主要是介绍web项目的菜单展示-三级联动菜单展示,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

三级联动菜单的展示

用的是Struts2 + Mybatis框架进行操作

文件结构

在这里插入图片描述在这里插入图片描述

核心代码

CasCade.jsp
<%@ page pageEncoding="UTF-8" contentType="text/html;UTF-8" isELIgnored="false"%>
<html>
<head><script type="application/javascript" src="${pageContext.request.contextPath}/js/jquery-1.8.3.min.js"></script><script type="application/javascript">$(function () {//展示所有的省份$.ajax({url:"${pageContext.request.contextPath}/cascade/showAllProvinces",type:"GET",dataType:"json",success:function (provinces) {//把所有的省份展示在第一个下拉列列表中for (var i=0;i<provinces.length;i++){//创建option标签var option=$("<option value="+provinces[i].code+">"+provinces[i].name+"</option>");$("#province").append(option);}//初始化北京对应的市$.ajax({url:"${pageContext.request.contextPath}/cascade/showCitys",type:"GET",data:"provincecode="+110000,dataType:"json",success:function (citys) {//每次添加清空$("#city").empty();//渲染该省份对应的市for (var i=0;i<citys.length;i++){var option=$("<option value="+citys[i].code+">"+citys[i].name+"</option>")$("#city").append(option);}//把第一个市对应的第一个区展示在第三个下拉框中$.ajax({url:"${pageContext.request.contextPath}/cascade/showAreas",type:"GET",data:"citycode="+110100, //把第一个市对应的code传入dataType:"json",success:function (areas) {$("#area").empty();for (var i=0;i<areas.length;i++){var option=$("<option>"+areas[i].name+"</option>");$("#area").append(option);}}})}})}});//给第一个省份的下拉框添加onchange事件$("#province").change(function () {//获取用户选中的codevar  provincecode=$("#province :selected").val();//把省份code传入后台$.ajax({url:"${pageContext.request.contextPath}/cascade/showCitys",type:"GET",data:"provincecode="+provincecode,dataType:"json",success:function (citys) {//每次添加清空$("#city").empty();//渲染该省份对应的市for (var i=0;i<citys.length;i++){var option=$("<option value="+citys[i].code+">"+citys[i].name+"</option>")$("#city").append(option);}//把第一个市对应的第一个区展示在第三个下拉框中$.ajax({url:"${pageContext.request.contextPath}/cascade/showAreas",type:"GET",data:"citycode="+citys[0].code, //把第一个市对应的code传入dataType:"json",success:function (areas) {$("#area").empty();for (var i=0;i<areas.length;i++){var option=$("<option>"+areas[i].name+"</option>");$("#area").append(option);}}})}})});//给第二个下拉框填充change事件$("#city").change(function () {//获取选中的citycodevar  citycode= $("#city option:selected").val();$.ajax({url:"${pageContext.request.contextPath}/cascade/showAreas",type:"GET",data:"citycode="+citycode,dataType:"json",success:function (areas) {$("#area").empty();for (var i=0;i<areas.length;i++){var option=$("<option>"+areas[i].name+"</option>");$("#area").append(option);}}})})})</script>
</head>
<body>
<select id="province">
</select>
<select id="city">
</select>
<select id="area">
</select>
</body>
</html>
一级菜单
public class ProvinceAction  extends ActionSupport {public  String  showAllProvinces(){ProvinceService ps=new ProvinceServiceImpl();//获取到所有省份List<Province> provinces = ps.showProvinces();//把List集合转换为JSON协议串String jsonString = JSON.toJSONString(provinces);HttpServletResponse response = ServletActionContext.getResponse();response.setCharacterEncoding("UTF-8");try {PrintWriter out = response.getWriter();out.print(jsonString);} catch (IOException e) {e.printStackTrace();}return  null;}
}
二级菜单
public class CityAction extends ActionSupport {//接受省份code  provincecodeprivate  String  provincecode;public String getProvincecode() {return provincecode;}public void setProvincecode(String provincecode) {this.provincecode = provincecode;}public  String   showCitys(){CityService cs= new CityServiceImpl();//查询该省份对应的所有的市List<City> cities = cs.showCitys(provincecode);//把List集合转换为JSON协议串String jsonString = JSON.toJSONString(cities);HttpServletResponse response = ServletActionContext.getResponse();response.setCharacterEncoding("UTF-8");try {PrintWriter out = response.getWriter();out.print(jsonString);} catch (IOException e) {e.printStackTrace();}return  null;}
}
三级菜单
public class AreaAction  extends ActionSupport {//接收citycodeprivate  String  citycode;public String getCitycode() {return citycode;}public void setCitycode(String citycode) {this.citycode = citycode;}public  String   showAreas(){AreaService as=new AreaServiceImpl();List<Area> areas = as.showAreas(citycode);//把List集合转换为JSON协议串String jsonString = JSON.toJSONString(areas);HttpServletResponse response = ServletActionContext.getResponse();response.setCharacterEncoding("UTF-8");try {PrintWriter out = response.getWriter();out.print(jsonString);} catch (IOException e) {e.printStackTrace();}return  null;}
}

实体类

public class Area {private  Integer  id;private  String   code;private  String   name;private  String   citycode;public class City {private  Integer  id;private  String   code;private  String   name;private  String   provincecode;public class Province {private  Integer  id;private  String   code;private  String   name;

这篇关于web项目的菜单展示-三级联动菜单展示的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1060907

相关文章

用Microsoft.Extensions.Hosting 管理WPF项目.

首先引入必要的包: <ItemGroup><PackageReference Include="CommunityToolkit.Mvvm" Version="8.2.2" /><PackageReference Include="Microsoft.Extensions.Hosting" Version="8.0.0" /><PackageReference Include="Serilog

eclipse运行springboot项目,找不到主类

解决办法尝试了很多种,下载sts压缩包行不通。最后解决办法如图: help--->Eclipse Marketplace--->Popular--->找到Spring Tools 3---->Installed。

vue项目集成CanvasEditor实现Word在线编辑器

CanvasEditor实现Word在线编辑器 官网文档:https://hufe.club/canvas-editor-docs/guide/schema.html 源码地址:https://github.com/Hufe921/canvas-editor 前提声明: 由于CanvasEditor目前不支持vue、react 等框架开箱即用版,所以需要我们去Git下载源码,拿到其中两个主

React+TS前台项目实战(十七)-- 全局常用组件Dropdown封装

文章目录 前言Dropdown组件1. 功能分析2. 代码+详细注释3. 使用方式4. 效果展示 总结 前言 今天这篇主要讲全局Dropdown组件封装,可根据UI设计师要求自定义修改。 Dropdown组件 1. 功能分析 (1)通过position属性,可以控制下拉选项的位置 (2)通过传入width属性, 可以自定义下拉选项的宽度 (3)通过传入classN

vue+elementUI下拉框联动显示

<el-row><el-col :span="12"><el-form-item label="主账号:" prop="partyAccountId" :rules="[ { required: true, message: '主账号不能为空'}]"><el-select v-model="detailForm.partyAccountId" filterable placeholder="

JavaWeb系列二十: jQuery的DOM操作 下

jQuery的DOM操作 CSS-DOM操作多选框案例页面加载完毕触发方法作业布置jQuery获取选中复选框的值jQuery控制checkbox被选中jQuery控制(全选/全不选/反选)jQuery动态添加删除用户 CSS-DOM操作 获取和设置元素的样式属性: css()获取和设置元素透明度: opacity属性获取和设置元素高度, 宽度: height(), widt

vue3项目将所有访问后端springboot的接口统一管理带跨域

vue3项目将所有访问后端springboot的接口统一管理带跨域 一、前言1.安装Axios2.创建Axios实例3.创建API服务文件4.在组件中使用API服务 二、跨域三、总结 一、前言 在Vue 3项目中,统一管理所有访问后端Spring Boot接口的最佳实践是创建一个专门的API服务层。这可以让你的代码更加模块化、可维护和集中管理。你可以使用Axios库作为HTT

vscode-创建vue3项目-修改暗黑主题-常见错误-element插件标签-用法涉及问题

文章目录 1.vscode创建运行编译vue3项目2.添加项目资源3.添加element-plus元素4.修改为暗黑主题4.1.在main.js主文件中引入暗黑样式4.2.添加自定义样式文件4.3.html页面html标签添加样式 5.常见错误5.1.未使用变量5.2.关闭typescript检查5.3.调试器支持5.4.允许未到达代码和未定义代码 6.element常用标签6.1.下拉列表

局域网内vue2 配置本地IP地址访问项目

在日常开发中同事可能需要访问你的前端项目,可以通过配置实现通过ip访问 一.首先找到config文件夹目录下的 index.js文件             将此处的host的值修改为0.0.0.0(即 host: 0.0.0.0) // Various Dev Server settings//host: 'localhost' //将localhost进行替换成 0.0.0.0host:

风水研究会官网源码系统-可展示自己的领域内容-商品售卖等

一款用于展示风水行业,周易测算行业,玄学行业的系统,并支持售卖自己的商品。 整洁大气,非常漂亮,前端内容均可通过后台修改。 大致功能: 支持前端内容通过后端自定义支持开启关闭会员功能,会员等级设置支持对接官方支付支持添加商品类支持添加虚拟下载类支持自定义其他类型字段支持生成虚拟激活卡支持采集其他站点文章支持对接收益广告支持文章评论支持积分功能支持推广功能更多功能,搭建完成自行体验吧! 原文