返回顶部
首页 > 资讯 > 后端开发 > Python >Mybatis + js 实现下拉列表二级联动效果
  • 854
分享到

Mybatis + js 实现下拉列表二级联动效果

2024-04-02 19:04:59 854人浏览 泡泡鱼

Python 官方文档:入门教程 => 点击学习

摘要

 一、业务需求 实现省份与城市的二级联动 二、实现效果 三、代码实现 1. province_city.jsp 前端界面实现 <%@ page contentT

 一、业务需求

实现省份与城市的二级联动

二、实现效果

在这里插入图片描述

三、代码实现

1. province_city.jsp

前端界面实现


<%@ page contentType="text/html;charset=UTF-8" language="java" isELIgnored="false" %>
<%@ taglib prefix="c" uri="Http://java.sun.com/jsp/jstl/core" %>
<html>
<head>
    <title>二级联动</title>
    <script src="/static/Jquery-1.11/jquery-1.11.3.min.js"></script>
    <script>
        // 页面加载完毕执行
        $(function () {
            let $p = $('#p');
            let $c = $('#c');
            // 给省份下拉框绑定值改变事件处理函数,当省份下拉框选项改变了,就发送请求获取这个省份对应
            // 城市数据,拿到数据再使用 DOM 显示在城市下拉框中
            $p.change(function () {
                // 获取被选中省份下拉框的 option 的 value 属性值,即省份 id 值
                let pid = $(this).val();

                // 清除旧有子元素(每次改变省份需要清除城市元素,否则城市元素会一直添加)
                $c.empty();
                // 请选择也被清除了,所以需要添加回来
                $c.append('<option value="-1">请选择</option>');
                // 判断是否选中了省份
                if (pid >= 1) {
                    $.post('/cities', 'pid=' + pid, function (data) {
                        // 遍历城市数组
                        data.forEach(function (value) {
                            console.log(value);
                            // 添加下拉元素
                            $c.append('<option value="' + value.id +'">' + value.name +'</option>');
                        });
                    });
                }
            });
        });
    </script>
</head>
<body>
省份:<select id="p">
    <option value="-1">请选择</option>
    <!-- 遍历后台传过来的省份集合 -->
    <c:forEach items="${allProvince}" var="province">
        <option value="${province.id}">${province.name}</option>
    </c:forEach>
</select>
城市:<select id="c">
    <option value="-1">请选择</option>
</select>
</body>
</html>

2. TwoController

后台处理方法


package com.yy.homework.WEB.controller;

import com.yy.homework.domain.City;
import com.yy.homework.domain.Province;
import org.springframework.stereotype.Controller;
import org.springframework.ui.Model;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.ResponseBody;

import java.util.List;

@Controller
public class TwoController {
    // 获取省份 JSON 数据
    @RequestMapping("/provinces")
    public String getProvinces(Model model) {
        List<Province> allProvince = Province.getAllProvince();
        model.addAttribute("allProvince", allProvince);
        return "forward:/province_city.jsp";
    }

    // 获取对应省份的城市 JSON 数据
    @RequestMapping("/cities")
    @ResponseBody
    public List<City> getCities(Long pid) {
        return City.getCityByProvinceId(pid);
    }
}

2. Province

为了让代码少一点,看的更清晰些,我伪造了一些省份数据,真实数据应该是你自己从数据库中查询出来的,封装成集合的形式给 Controller 调用


package com.yy.homework.domain;

import java.util.ArrayList;
import java.util.List;

public class Province {
    private Long id;
    private String name;
    public Province() {
    }
    public Province(Long id, String name) {
        this.id = id;
        this.name = name;
    }
    public Long getId() {
        return id;
    }
    public String getName() {
        return name;
    }
    // 获取所有的省份
    public static List<Province> getAllProvince() {
        List<Province> provinces = new ArrayList<Province>();
        provinces.add(new Province(1L, "湖南"));
        provinces.add(new Province(2L, "广东"));
        provinces.add(new Province(3L, "湖北"));
        return provinces;
    }
}

3. Province

这里是我伪造的一些城市数据,真实数据应该是你自己根据前台页面传过来的 省份 id数据库中查询出来的,封装成集合的形式给 Controller 调用,返回前端界面


package com.yy.homework.domain;

import java.util.ArrayList;
import java.util.Arrays;
import java.util.List;


public class City {
    private Long id;
    private String name;

    public City() {
    }
    public City(Long id, String name) {
        this.id = id;
        this.name = name;
    }
    public Long getId() {
        return id;
    }
    public String getName() {
        return name;
    }
    public String toString() {
        return "City [id=" + id + ", name=" + name + "]";
    }
    
    public static List<City> getCityByProvinceId(Long pid) {
        List<City> citys = new ArrayList<City>();
        if (pid == 1) {
            citys = Arrays.asList(
                    new City(11L, "长沙市"),
                    new City(12L, "株洲市"),
                    new City(13L, "湘潭市"),
                    new City(14L, "衡阳市"),
                    new City(15L, "邵阳市"),
                    new City(16L, "岳阳市"),
                    new City(17L, "常德市"),
                    new City(18L, "张家界市")
            );
        } else if (pid == 2) {
            citys = Arrays.asList(
                    new City(21L, "广州市"),
                    new City(22L, "深圳市"),
                    new City(23L, "佛山市"),
                    new City(24L, "中山市"),
                    new City(25L, "珠海市"),
                    new City(26L, "汕头市"),
                    new City(27L, "潮州市"),
                    new City(28L, "东莞市")
            );
        } else if (pid == 3) {
            citys = Arrays.asList(
                    new City(31L, "孝感市"),
                    new City(32L, "黄冈市"),
                    new City(33L, "咸宁市"),
                    new City(34L, "恩施州"),
                    new City(35L, "鄂州市"),
                    new City(36L, "武汉市"),
                    new City(37L, "荆门市"),
                    new City(38L, "襄阳市")
            );
        }
        return citys;
    }
}

总结

以上就是用二级联动的代码了,代码仅供参考,欢迎讨论交流。

以上就是mybatis + js 实现下拉列表二级联动的详细内容,更多关于Mybatis下拉列表二级联动的资料请关注编程网其它相关文章!

--结束END--

本文标题: Mybatis + js 实现下拉列表二级联动效果

本文链接: https://lsjlt.com/news/128092.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Mybatis + js 实现下拉列表二级联动效果
     一、业务需求 实现省份与城市的二级联动 二、实现效果 三、代码实现 1. province_city.jsp 前端界面实现 <%@ page contentT...
    99+
    2024-04-02
  • vue如何实现下拉框二级联动效果
    这篇文章主要介绍vue如何实现下拉框二级联动效果,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!1、实现效果2、后端返回的数据格式"list": [   &n...
    99+
    2023-06-25
  • js如何实现二级联动效果
    这篇文章主要介绍js如何实现二级联动效果,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!示例代码:<!DOCTYPE html> <html> <...
    99+
    2024-04-02
  • vue实现下拉框二级联动效果的实例代码
    1、实现效果 2、后端返回的数据格式 "list": [ { "id": "1178214681118568449", "title...
    99+
    2024-04-02
  • JS+AJAX实现省市区的下拉列表联动
    本文实例为大家分享了JS+AJAX实现省市区下拉列表联动的具体代码,供大家参考,具体内容如下 效果图如下,DB中存取的数据来抽取. 前台JSP页面的实现 <div cla...
    99+
    2024-04-02
  • AndroidStudio实现下拉列表效果
    本文实例为大家分享了Android Studio实现下拉列表的具体代码,供大家参考,具体内容如下 题目 使用 ArrayAdapter 的方式实现一个城市的下拉列表。 答案 acti...
    99+
    2024-04-02
  • JavaScript实现下拉列表效果
    本文实例为大家分享了JavaScript实现下拉列表效果的具体代码,供大家参考,具体内容如下 这一次写了一个比较简单的下拉列表的实现,点击出现列表内容,再次点击列表消失,研究了很久,...
    99+
    2024-04-02
  • Android实现三级联动下拉框 下拉列表spinner的实例代码
    主要实现办法:动态加载各级下拉值的适配器 在监听本级下拉框,当本级下拉框的选中值改变时,随之修改下级的适配器的绑定值        &...
    99+
    2022-06-06
    spinner 级联 下拉框 Android
  • ajax如何实现三级联动下拉菜单效果
    这篇文章给大家分享的是有关ajax如何实现三级联动下拉菜单效果的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。ajax写三级联动,先写一个文件类吧,以后用的时候直接调用即可;来找一...
    99+
    2024-04-02
  • React+ts实现二级联动效果
    本文实例为大家分享了React+ts实现二级联动效果的具体代码,供大家参考,具体内容如下 .tsx文件 import { Component, createRef} from 're...
    99+
    2024-04-02
  • React实现二级联动效果(楼梯效果)
    本文实例为大家分享了React实现二级联动效果的具体代码,供大家参考,具体内容如下 模仿饿了么实现一个二级联动的效果; import "../css/Leftrightlinka...
    99+
    2024-04-02
  • Ajax如何实现列表无限加载和二级下拉选项效果
    这篇文章给大家分享的是有关Ajax如何实现列表无限加载和二级下拉选项效果的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。具体内容如下//栏目Ajax做加载public function ajax...
    99+
    2023-06-08
  • js如何实现三级联动效果
    小编给大家分享一下js如何实现三级联动效果,相信大部分人都还不怎么了解,因此分享这篇文章给大家参考一下,希望大家阅读完这篇文章后大有收获,下面让我们一起去了解一下吧!示例代码如下:<!DOCTYPE&...
    99+
    2024-04-02
  • jquery如何实现二级联动效果
    这篇文章给大家分享的是有关jquery如何实现二级联动效果的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。具体内容如下<!DOCTYPE html> <...
    99+
    2024-04-02
  • bootstrap如何实现二级下拉菜单效果
    这篇文章将为大家详细讲解有关bootstrap如何实现二级下拉菜单效果,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。具体内容如下<!DOCTYPE htm...
    99+
    2024-04-02
  • 如何实现AJAX下拉框省、市二级联动
    本篇内容介绍了“如何实现AJAX下拉框省、市二级联动”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!jsp页...
    99+
    2024-04-02
  • Android Studio如何实现下拉列表效果
    这篇文章主要讲解了“Android Studio如何实现下拉列表效果”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“Android Studio如何实现下拉列表效果”吧!题...
    99+
    2023-06-30
  • vue实现列表左右联动效果
    本文实例为大家分享了vue实现列表左右联动效果的具体代码,供大家参考,具体内容如下 先谈需求:左侧为分类列表,点击分类名右侧商品列表会滑动对应分类到顶部;右侧商品列表滑动到某一分类时...
    99+
    2024-04-02
  • JavaScript中怎么实现一个二级联动下拉框
    JavaScript中怎么实现一个二级联动下拉框,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。Javascript是一种由Netscape...
    99+
    2024-04-02
  • JS如何实现五级联动菜单效果
    这篇文章主要为大家展示了“JS如何实现五级联动菜单效果”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“JS如何实现五级联动菜单效果”这篇文章吧。js实现多级联动的...
    99+
    2024-04-02
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作