最简单的el-cascadert省市区三级/二级联动

需求:需要实现省市区的三级联动或者二级联动的功能,找了半天找到这个最简单的插件实现,无需自己找json,直接下载导入就有了。

插件地址:element-china-area-data - npm (npmjs.com)

里面有使用方法,我就是跟着里面的方法写的,此贴就是记录贴。

1.效果

2.下载插件

我下的最新版,这边要注意一下,有些小伙伴下的是旧版,旧版的**codeToText是大写的C,**新版改成小写了

复制代码
npm install element-china-area-data

3.导入

这个根据需求导入哈

字段讲解:

  1. provinceAndCityData省市二级联动数据,汉字+code
  2. regionData省市区三级联动数据
  3. pcTextArr省市联动数据,纯汉字
  4. pcaTextArr省市区联动数据,纯汉字
  5. codeToText是个大对象,属性是区域码,属性值是汉字 用法例如:codeToText['110000']输出北京市
javascript 复制代码
import {
  provinceAndCityData,
  pcTextArr,
  regionData,
  pcaTextArr,
  codeToText,
} from "element-china-area-data"; //导入地图数据

4.二级联动使用

javascript 复制代码
<template>
  <div id="app">
    <el-cascader
      size="large"
      :options="provinceAndCityData"
      v-model="selectedOptions">
    </el-cascader>
  </div>
</template>

<script>
  import { provinceAndCityData } from 'element-china-area-data'
  export default {
    data () {
      return {
        provinceAndCityData,
        selectedOptions: []
      }
    },
  }
</script>

效果

5.省市区三级联动

javascript 复制代码
<template>
    <div class="content-box">
        <div class="container">
                <el-cascader
                    size="large"
                    clearable
                    ref="cascader"
                    :options="options"
                    v-model="params.selectedOptions"
                    @change="handleChange"
                    class="w250"
                >
                </el-cascader>
        </div>
    </div>
</template>

<script>
import {
  provinceAndCityData,
  pcTextArr,
  regionData,
  pcaTextArr,
  codeToText,
} from "element-china-area-data"; //导入地图数据

export default {
    data() {
        return {
            options: regionData,
            params: {
                //params为向后台发送请求的请求体,为什么要将selectedOptions写在请求体中请向后看
                selectedOptions: [],
            }
        };
    },
    mounted(){
      console.log(provinceAndCityData,'二级市区');
    },
    methods: {
        // 地图
        handleChange(e) {
          console.log(e,'省市区');
        }
    }
};
</script>

<style lang="scss" scoped></style>

还有其他的可以自行探索,文章到此结束,希望对你有所帮助~

相关推荐
澄江静如练_1 分钟前
表单输入绑定
服务器·前端·javascript
猩球中的木子4 分钟前
vue-plugin-hiprint打印高度不够,提示:没有足够空间,显示下方内容,问题处理方案及实操
前端·vue.js
狗头大军之江苏分军15 分钟前
Node.js 原生功能越来越强,我们是不是被 npm 玩坏了?
前端·javascript·架构
独自破碎E18 分钟前
TS7016: Could not find a declaration file for module ‘vue-router‘.解决办法
前端·javascript·vue.js
仰望星空@脚踏实地26 分钟前
DataKit js-yaml和follow-redirects组件依赖影响分析
前端·datakit
RustFS26 分钟前
RustFS 如何实现对象存储的前端直传?
vue.js·docker·rust
用户4672695597611 小时前
vue 表格 vxe-table 树结构实现单元格复制粘贴功能,实现树层级节点复制功能
vue.js
Mr_fang719401 小时前
iframe 导致 Vue Router go(-1) 无法正常返回问题解决方案
前端
Drift_Dream1 小时前
Node.js 第二课:用核心模块构建你的第一个服务器
前端·后端
DEMO派1 小时前
首页图片懒加载实现方案解析
前端