用elementui实现省市区三级联动

利用本地地图json文件储存省市区信息

json文件来源  https://pan.baidu.com/s/1g-BitDJ5wld1UgHhiHjcFA  密码:s1lb

vue文件

<template>
  <div class="linkage">
    <div>
      <el-select v-model="selectProvince" filterable size="small" value-key="areacode"  @change="selectProvinceFun($event)" placeholder="请选择省份">
        <!-- <el-option value="" label="请选择省份"></el-option> -->
        <el-option :value="item" :label="item.areaname" v-for="item in city" :key="item.areacode"></el-option>
      </el-select>
    </div>
    <div>
      <el-select v-model="selectCity" filterable size="small" value-key="areacode" @change="selectCityFun($event)" placeholder="请选择城市">
        <!-- <el-option value="" label="请选择城市"></el-option> -->
        <el-option :value="item" :label="item.areaname" v-for="item in cityList" :key="item.areacode"></el-option>
      </el-select>
    </div>
    <div>
      <el-select v-model="selectArea" filterable size="small" value-key="areacode" @change="selectAreaFun($event)" placeholder="请选择区县">
        <!-- <el-option value="" label="请选择区县"></el-option> -->
        <el-option :value="item" :label="item.areaname" v-for="item in areaList" :key="item.areacode"></el-option>
      </el-select>
    </div>
  </div>
</template>
<script>
//引用地图json文件
import city from '@/assets/json/city.json'
export default {
  name: 'linkage',
  data () {
    return {
      // 整个省市县数据
      city: city,
      // 被选中的市数据
      cityList: [],
      // 被选中的县数据
      areaList: [],
      selectProvince: '',
      selectCity: '',
      selectArea: ''
    }
  },
  mounted () {
  },
  methods: {
    // 省份 市 县联动
    selectProvinceFun (event) {
      console.log(event)
      if (event) {
        this.cityList = event.subarea
      } else {
        this.cityList = []
      }
      this.areaList = []
      // this.$emit('getLawyerListInfo', [event.areaname, 'province'])
      this.selectProvince=event.areaname
      this.$forceUpdate();
    },
    selectCityFun (event) {
      console.log(event)
      if (event) {
        this.areaList = event.subarea
      } else {
        this.areaList = []
      }
      // this.$emit('getLawyerListInfo', [event.areaname, 'city'])
      this.selectCity=event.areaname
      this.$forceUpdate();
    },
    selectAreaFun (event) {
      console.log(event)
      // this.$emit('getLawyerListInfo', [event.areaname, 'area'])
      this.selectArea=event.areaname
      this.$forceUpdate();
    }
  }
}
</script>

<style>
  .linkage{
    display: flex;
  }
  .linkage div{
    margin-right: 5px;
  }
</style>

 参考来源vue + elementUI 省市县三级联动 - SegmentFault 思否

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值