亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 網站 > 幫助中心 > 正文

基于Vue+ElementUI的省市區地址選擇通用組件

2024-07-09 22:41:39
字體:
來源:轉載
供稿:網友

一、緣由

在項目開發過程中,有一個需求是省市區地址選擇的功能,一開始想的是直接使用靜態地址資源庫本地打包,但這種方式不方便維護,于是放棄。后來又想直接讓后臺返回全部地址數據,然后使用級聯選擇器進行選擇,但發現數據傳輸量有點大且處理過程耗時,于是又摒棄了這種方法。最后還是決定采用異步的方式進行省市區地址選擇,即先查詢省份列表,然后根據選擇的省份code查詢城市列表,最后根據選擇的城市列表獲取區/縣列表,最終根據應用場景不同,給出了兩種實現方案。

其中后臺總共需要提供4個接口,一個查詢所有省份的接口,一個根據省份code查詢其下所有城市的接口,一個根據城市code查詢其下所有區/縣的接口,以及一個根據地址code轉換成省市區三個code值的接口。

// 本人項目中使用的四個接口`${this.API.province}/${countryCode}` // 根據國家code查詢省份列表,中國固定為156,可以拓展`${this.API.city }/${provinceCode}` // 根據省份code查詢城市列表`${this.API.area}/${cityCode}` // 根據城市code查詢區/縣列表`${this.API.addressCode}/${addressCode}` // 地址code轉換為省市區code

二、基于el-cascader 級聯選擇器的單選擇框實現方案

<template> <el-row>  <el-cascader   size="small"   :options="city.options"   :props="props"   v-model="cityValue"   @active-item-change="handleItemChange"   @change="cityChange">  </el-cascader> </el-row></template><script>export default { name: 'addressSelector', props: {  areaCode: null }, model: {  prop: 'areaCode',  event: 'cityChange' }, data () {  return {   // 所在省市   city: {    obj: {},    options: []   },   props: { // 級聯選擇器的屬性配置    value: 'value',    children: 'cities',    checkStrictly: true   },   cityValue: [], // 城市代碼  } }, computed: { }, created () {  this._initData() }, mounted () { }, methods: {  _initData () {   this.$http({    method: 'get',    url: this.API.province + '/156' // 中國   }).then(res => {    this.city.options = res.data.body.map(item => { // 所在省市     return {      value: item.provinceCode,      label: item.provinceName,      cities: []     }    })   })  },  getCodeByAreaCode (code) {   if (code == undefined) return false   this.$http({    method: 'get',    url: this.API.addressCode + '/' + code   })   .then(res => {    if (res.data.code === this.API.SUCCESS) {     let provinceCode = res.data.body.provinceCode     let cityCode = res.data.body.cityCode     let areaCode = res.data.body.areaCode     this.cityValue = [provinceCode, cityCode, areaCode]     this.handleItemChange([provinceCode, cityCode])    }   })   .finally(res => {   })  },  handleItemChange (value) {   let a = (item) => {    this.$http({     method: 'get',     url: this.API.city + '/' + value[0],    }).then(res => {     item.cities = res.data.body.map(ite => {      return {       value: ite.cityCode,       label: ite.cityName,       cities: []      }     })     if(value.length === 2){ // 如果傳入的value.length===2 && 先執行的a(),說明是傳入了areaCode,需要初始化多選框      b(item)     }    }).finally(_ => {    })   }   let b = (item) => {    if (value.length === 2) {     item.cities.find(ite => {      if (ite.value === value[1]) {       if (!ite.cities.length) {        this.$http({         method: 'get',         url: this.API.area + '/' + value[1]        }).then(res => {         ite.cities = res.data.body.map(ite => {          return {           value: ite.areaCode,           label: ite.areaName,          }         })        }).finally(_ => {        })       }      }     })    }   }   this.city.options.find(item => {    if (item.value === value[0]) {     if (item.cities.length) {      b(item)     } else {      a(item)     }     return true    }   })  },  getCityCode () {   return this.cityValue[2]  },  reset () {   this.cityValue = []  },  cityChange (value) {   if (value.length === 3) {    this.$emit('cityChange', value[2])   } else {    this.$emit('cityChange', null)   }  } }, watch: {  areaCode: {   deep: true,   immediate: true,   handler (newVal) {    if (newVal) {     this.getCodeByAreaCode(newVal)    } else {     this.$nextTick(() => {      this.reset()     })    }   }  } }}</script><style lang="less" scoped></style>
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产精品高精视频免费| 亚洲国产日韩欧美综合久久| 5566成人精品视频免费| 国产综合福利在线| 亚洲色图17p| 在线观看日韩专区| 日韩av电影在线播放| 国产成人精品日本亚洲| 国产欧美一区二区三区久久| 亚洲va欧美va在线观看| 日韩资源在线观看| 日韩美女视频免费在线观看| 91爱视频在线| 国产成人综合精品在线| 国内免费精品永久在线视频| 久久综合久久美利坚合众国| 2019中文字幕全在线观看| 亚洲激情电影中文字幕| 97国产精品视频| 国产精品男人的天堂| 亚洲国产精品va在线看黑人| 国产精品美女999| 中文字幕九色91在线| 精品久久香蕉国产线看观看gif| 欧美性猛交xxxx免费看| 久久电影一区二区| 综合久久五月天| 黄色精品一区二区| 色小说视频一区| 国产日韩欧美电影在线观看| 亚洲大胆人体在线| 亚洲网在线观看| 国产精品狼人色视频一区| 精品福利在线观看| 97香蕉超级碰碰久久免费的优势| 欧美激情一级二级| 国产精品入口尤物| 在线观看亚洲区| 欧美日韩成人网| 成人国产精品一区二区| 日韩电影中文字幕av| 影音先锋欧美精品| 亚洲一区亚洲二区亚洲三区| 国产精品第一页在线| 777精品视频| 欧美成人中文字幕在线| 亚洲欧美日韩另类| 久久久精品免费视频| 国产精品日韩在线一区| 国产精品永久免费观看| 欧美国产精品人人做人人爱| 2019国产精品自在线拍国产不卡| 久久夜色精品国产亚洲aⅴ| 亚洲一区二区免费在线| 色偷偷偷综合中文字幕;dd| 久久精品中文字幕一区| 亚洲第一网站免费视频| 在线亚洲午夜片av大片| 亚洲永久免费观看| 久久露脸国产精品| 欧美一区二区视频97| 77777亚洲午夜久久多人| 亚洲三级免费看| 亚洲成在人线av| 91在线高清免费观看| 国产成人精品免费久久久久| 久久久国产精品亚洲一区| 成人精品网站在线观看| 日韩欧美999| 深夜福利国产精品| 欧美国产日韩xxxxx| 国产精品视频久久| 精品福利免费观看| 日韩电影免费观看在线观看| 日韩免费视频在线观看| 色婷婷久久一区二区| 国产精品免费久久久| 欧美一级片一区| 国产精品狠色婷| 久久99久国产精品黄毛片入口| 91国偷自产一区二区三区的观看方式| 欧美日韩激情视频8区| 欧美午夜女人视频在线| 亚洲va久久久噜噜噜久久天堂| 精品久久香蕉国产线看观看gif| 亚洲欧美综合区自拍另类| 欧美肥婆姓交大片| 欧美小视频在线| 日韩免费av在线| 色综合伊人色综合网| 亚洲欧美中文字幕| www.亚洲男人天堂| 亚洲视频在线观看网站| 日韩乱码在线视频| 亚洲一区美女视频在线观看免费| 国产精品久久久久久久美男| 日本欧美一级片| 欧美极品美女电影一区| 91亚洲精品一区| 久久久久久伊人| 精品久久久久久久久久久久久| 91沈先生作品| 精品国产鲁一鲁一区二区张丽| 国产一区二区三区丝袜| 国产视频久久网| 国产v综合v亚洲欧美久久| 亚洲福利视频专区| 日本欧美爱爱爱| 久久久久久尹人网香蕉| 亚洲精品一二区| 不卡伊人av在线播放| 亚洲精品99久久久久中文字幕| 正在播放国产一区| 国产精品久久久久久久久久99| 精品无人区太爽高潮在线播放| 北条麻妃99精品青青久久| 动漫精品一区二区| 亚洲成人激情在线观看| 欧美福利在线观看| 国产成人福利网站| 久久精品国产欧美激情| 日本精品视频在线| 欧美色图在线视频| 欧美日韩国产999| 日本道色综合久久影院| 日韩欧美极品在线观看| 亚州国产精品久久久| 青草热久免费精品视频| 国产精品第8页| 久久久久久有精品国产| 亚洲精品自产拍| 日韩av电影手机在线| 有码中文亚洲精品| 国产一区二区三区精品久久久| 中日韩美女免费视频网站在线观看| 中文字幕日韩av电影| 成人网在线免费观看| 国产在线视频不卡| 国产高清在线不卡| 精品一区电影国产| 国产日韩欧美另类| 国产精品网站入口| 亚洲视频网站在线观看| 亚洲毛片在线观看.| 亚洲色图在线观看| 精品久久久视频| 日本韩国欧美精品大片卡二| 国产成人avxxxxx在线看| 亚洲最大福利视频| 亚洲另类xxxx| 在线观看日韩www视频免费| 怡红院精品视频| 国产suv精品一区二区三区88区| 色综合久久久久久中文网| 色综合久久悠悠| 美女视频久久黄| 伊人亚洲福利一区二区三区| 日韩一二三在线视频播| 欧美高清理论片| 亚洲精品福利在线观看| 久久影院资源网| 国产一区二区在线免费| 亚洲国产精品成人一区二区| 欧美日韩亚洲高清|