Vue整合element-china-area-data实现PC端省市区三级联动选择器

简介: demo环境是SpringBoot+Vue+elementUI,开发工具是idea,有涉及到省市区三级联动选择器,网上查找了下,发现了这款和elementUI相匹配的element-china-area-data,这样的话样式什么的就不用担心会很丑,也不需要调,最主要是还可以直接获取到省市区编码,都不用通过后台接口转换。于是就撸起袖子,满心欢喜的整进来。

1、前言

demo环境是SpringBoot+Vue+elementUI,开发工具是idea,有涉及到省市区三级联动选择器,网上查找了下,发现了这款和elementUI相匹配的element-china-area-data,这样的话样式什么的就不用担心会很丑,也不需要调,最主要是还可以直接获取到省市区编码,都不用通过后台接口转换。于是就撸起袖子,满心欢喜的整进来。效果如文末所示。

2、下载代码包

官网地址:https://www.npmjs.com/package/element-china-area-data

从官网上下载代码包放到项目中,可以把不需要的文件及文件夹删除,demo这边是没有删除。如下图所示:

image.png

image.png

3、安装china-area-data

在idea中打开终端工具,执行 npm install china-area-data 安装省市区数据,一会儿就好。如下图所示:

image.png

4、js代码

参考官方demo依葫芦画瓢,这里举的例子是不带“全部”选项的省市区三级联动

  el:'#demo',
  data:{
    areaOptions: [],    
    selectedOptions: []
  },
  methods: {
    add: function(){
      vue.areaOptions = regionData;
    },
    update: function (event) {
      var id = getSelectedRow();
      if(id == null){
        return ;
      }
      vue.areaOptions = regionData;
    },
    //表单区域值改变时触发
    areaHandleChange (value) {
      //这里可以把获取到的value值赋值给后台字段做存储使用
      //value是数组,如 绑定值:[ "330000", "330100", "330106" ]
      //只需要把区存到后台数据库即可,即取到value[2]即可,在数据回显时,便可以自动显示整个省市区
      //非常方便简介
      //CodeToText是个大对象,属性是区域码,属性值是汉字 用法例如:CodeToText['110000']输出北京市
      //TextToCode是个大对象,属性是汉字,属性值是区域码 用法例如:TextToCode['北京市'].code输出110000,TextToCode['北京市']['市辖区'].code输出110100,TextToCode['北京市']['市辖区']['朝阳区'].code输出110105     
      //想获取到省市区中文的话,就这样写:CodeToText[value[0]]+CodeToText[value[1]]+CodeToText[value[2]];
    }
  }

5、html代码


<div class="form-group">
    <div class="col-sm-2 control-label">省市区三级联动</div>
    <div class="col-sm-10">
        <el-cascader
                size="large"
                :options="areaOptions"
                v-model="selectedOptions"
                @change="areaHandleChange">
        </el-cascader>
    </div>
</div>

6、效果

image.png

山水有相逢,来日皆可期,谢谢阅读,我们再会

我手中的金箍棒,上能通天,下能探海

上一篇:linux安装jenkins

相关文章
|
3天前
|
缓存 监控 JavaScript
探讨优化Vue应用性能和加载速度的策略
【5月更文挑战第17天】本文探讨了优化Vue应用性能和加载速度的策略:1) 精简代码和组件拆分以减少冗余;2) 使用计算属性和侦听器、懒加载、预加载和预获取优化路由;3) 数据懒加载和防抖节流处理高频事件;4) 图片压缩和选择合适格式,使用CDN加速资源加载;5) 利用浏览器缓存和组件缓存提高效率;6) 使用Vue Devtools和性能分析工具监控及调试。通过这些方法,可提升用户在复杂应用中的体验。
10 0
|
4天前
|
JavaScript 前端开发
vue(1),小白看完都会了
vue(1),小白看完都会了
|
3天前
|
JavaScript 开发工具 git
Vue 入门系列:.env 环境变量
Vue 入门系列:.env 环境变量
10 1
|
3天前
|
JavaScript
vue知识点
vue知识点
11 0
|
4天前
|
JavaScript 前端开发 定位技术
Vue使用地图以及实现轨迹回放 附完整代码
Vue使用地图以及实现轨迹回放 附完整代码
Vue使用地图以及实现轨迹回放 附完整代码
|
数据库
基于springboot+mybatisplus+vue的课程学分管理系统
基于springboot+mybatisplus+vue的课程学分管理系统
105 0
基于springboot+mybatisplus+vue的课程学分管理系统
基于Springboot+MybatisPlus+Vue的在线课程管理系统
基于Springboot+MybatisPlus+Vue的在线课程管理系统
112 0
基于Springboot+MybatisPlus+Vue的在线课程管理系统
|
JavaScript 前端开发 Java
基于Springboot+MybatisPlus+Vue的前后端分离的学生选课课程教务管理系统
基于Springboot+MybatisPlus+Vue的前后端分离的学生选课课程教务管理系统
189 0
基于Springboot+MybatisPlus+Vue的前后端分离的学生选课课程教务管理系统
|
JavaScript 开发者
Vue 课程介绍|学习笔记
快速学习 Vue 课程介绍
97 0
|
JavaScript 开发者
Vue课程介绍|学习笔记
快速学习Vue课程介绍
76 0