欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

利用vue+elementUI設(shè)置省市縣三級聯(lián)動(dòng)下拉列表框的詳細(xì)過程

 更新時(shí)間:2022年08月03日 15:45:21   作者:動(dòng)飛雨  
在做電商項(xiàng)目的時(shí)候需要添加修改收貨地址,如何實(shí)現(xiàn)三級聯(lián)動(dòng)選取省市區(qū)地址困擾了我不少時(shí)間,這篇文章主要給大家介紹了關(guān)于利用vue+elementUI設(shè)置省市縣三級聯(lián)動(dòng)下拉列表框的相關(guān)資料,需要的朋友可以參考下

前言

在前端項(xiàng)目開發(fā)中,經(jīng)常會(huì)遇到省市縣三級聯(lián)動(dòng)的下拉列表框組的問題,分享以下實(shí)現(xiàn)方法,以下內(nèi)容為具體的實(shí)現(xiàn)過程:

實(shí)現(xiàn)過程

1.靜態(tài)頁面組件搭建:使用elementUI的form表單,并做一下基本的修改,得到以下結(jié)果:

2.然后是組件的數(shù)據(jù)配置:

表單的基本數(shù)據(jù)存放在form對象里面,至于省市縣三個(gè)下拉菜單的數(shù)據(jù),則以數(shù)組的形式存放,分別為provinceList[];cityList[];countyListp[]。

3.接下來處理重點(diǎn)數(shù)據(jù):三級下拉菜單的聯(lián)動(dòng):

3.1點(diǎn)擊省下拉菜單獲取省份:

 主要技術(shù)點(diǎn)在于:通過調(diào)取百度地圖的API接口,獲取全國省市縣行政區(qū)劃:

this.$http({
              method:"get",
              url:"https://restapi.amap.com/v3/config/district?parameters",
              params:{
                  key:"3a708a4ef5e3af28694b1c861985a5ce",
                  keyWords:"中國",
                  subdistrict:3
              }
}).then((res)=>{
       this.form.provinceList = res.data.districts[0].districts  /* 省*/
         /* 進(jìn)行遍歷賦值*/
         /* 市區(qū)和縣區(qū)*/
       let newProvince = this.form.provinceList
       for(let i = 0; i < newProvince.length; i++){              /* 省級*/
           for(let j = 0; j < newProvince[i].districts.length; j++){       /* 市級*/
               let city = newProvince[i].districts[j].name
               this.CITY.push({id:j+1,name:city,code:i+1})
               for(let k = 0;k<newProvince[i].districts[j].districts.length; k++){/* 縣級*/
                   let xian = newProvince[i].districts[j].districts[k].name
                    this.XIAN.push({id:k+1,name:xian,code:j+1,cityCountyName:city})
               }
           }
       }
       for(let m = 0; m < newProvince.length;m++){
           newProvince[m] = {...newProvince[m],...{code:m+1}}
       }
       this.form.provinceList = newProvince
})

上述代碼的作用:在 獲取百度地圖提供的行政區(qū)劃后,對這些行政區(qū)劃樹進(jìn)行初始化,主要是給選各個(gè)省份匹配其對應(yīng)的市和縣級行政區(qū)。

接下來的操作就是點(diǎn)擊選擇省份就可以獲取其對應(yīng)的 市級行政區(qū),點(diǎn)擊選擇市級下拉菜單就可以獲取其對應(yīng)的縣級行政區(qū),代碼如下:

根據(jù)選中省,匹配市:

provinceChange(that){
    // 根據(jù)選中省,匹配市
    let cityCode = 0
    let newCityArry = []
    this.form.provinceList.forEach((item,index)=>{
        if(item.name == that){
            cityCode = item.code
        }
    })
       // console.log(cityCode)
    if(cityCode){
        this.form.cityList = []
        this.CITY.forEach((item,index)=>{
            if(item.code == cityCode){
                this.form.cityList.push(item)
            }
        })  /* 市匹配成功*/
    }
},

 // 根據(jù)市區(qū),匹配縣區(qū)

cityChange(that){
                let countyCode = 0
                let cityname = ''
                let newCountyArry = []
                this.form.cityList.forEach((item,index)=>{
                    if(item.name == that){
                        countyCode = item.id
                        cityname = item.name
                    }
                })
                if(countyCode){
                    this.form.countyList = []
                    this.XIAN.forEach((item,index)=>{
                        if(item.code == countyCode && item.cityCountyName == cityname){
                            this.form.countyList.push(item)
                        }
                    })
                }
            },

做了這些程序配置后,就可以實(shí)現(xiàn)三級下拉菜單的聯(lián)動(dòng)了。效果圖如下

總結(jié)

到此這篇關(guān)于利用vue+elementUI設(shè)置省市縣三級聯(lián)動(dòng)下拉列表框的文章就介紹到這了,更多相關(guān)vue+elementUI省市縣三級聯(lián)動(dòng)下拉列表框內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 一文快速學(xué)會(huì)阻止事件冒泡的4種方法(原生js阻止,vue中使用修飾符阻止)

    一文快速學(xué)會(huì)阻止事件冒泡的4種方法(原生js阻止,vue中使用修飾符阻止)

    冒泡就是事件開始是由最具體的元素接收,然后逐層向上級傳播到較為不具體的元素,這篇文章主要給大家介紹了關(guān)于阻止事件冒泡的4種方法,文中介紹的方法分別是原生js阻止以及vue中使用修飾符阻止的相關(guān)資料,需要的朋友可以參考下
    2023-12-12
  • 詳解在vue-cli中使用路由

    詳解在vue-cli中使用路由

    本篇文章主要介紹了詳解在vue-cli中使用路由,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2017-09-09
  • 解決Vue3.0刷新頁面警告[Vue Router warn]:No match found for location with path /xxx

    解決Vue3.0刷新頁面警告[Vue Router warn]:No match 

    這篇文章主要介紹了解決Vue3.0刷新頁面警告[Vue Router warn]:No match found for location with path /xxx問題,具有很好的參考價(jià)值,希望對大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • Vue的雙向數(shù)據(jù)綁定實(shí)現(xiàn)原理解析

    Vue的雙向數(shù)據(jù)綁定實(shí)現(xiàn)原理解析

    這篇文章主要介紹了Vue的雙向數(shù)據(jù)綁定實(shí)現(xiàn)原理解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-02-02
  • vue實(shí)現(xiàn)父子組件之間的通信以及兄弟組件的通信功能示例

    vue實(shí)現(xiàn)父子組件之間的通信以及兄弟組件的通信功能示例

    這篇文章主要介紹了vue實(shí)現(xiàn)父子組件之間的通信以及兄弟組件的通信功能,結(jié)合實(shí)例形式分析了vue.js組件間通信相關(guān)操作技巧,需要的朋友可以參考下
    2019-01-01
  • 一文搞懂vue中provide和inject實(shí)現(xiàn)原理對抗平庸

    一文搞懂vue中provide和inject實(shí)現(xiàn)原理對抗平庸

    這篇文章主要為大家介紹了vue中provide和inject實(shí)現(xiàn)原理的深入理解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04
  • Vue EventBus自定義組件事件傳遞

    Vue EventBus自定義組件事件傳遞

    這篇文章主要介紹了Vue EventBus自定義組件事件傳遞,組件化應(yīng)用構(gòu)建是Vue的特點(diǎn)之一,本文主要介紹EventBus進(jìn)行數(shù)據(jù)消息傳遞 ,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-06-06
  • vue實(shí)現(xiàn)文件上傳

    vue實(shí)現(xiàn)文件上傳

    這篇文章主要為大家詳細(xì)介紹了vue實(shí)現(xiàn)文件上傳功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • vue封裝組件js版基本步驟

    vue封裝組件js版基本步驟

    這篇文章主要為大家介紹了vue封裝組件js版基本步驟,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-04-04
  • Vue.js中該如何自己維護(hù)路由跳轉(zhuǎn)記錄

    Vue.js中該如何自己維護(hù)路由跳轉(zhuǎn)記錄

    這篇文章主要給大家介紹了關(guān)于Vue.js中該如何自己維護(hù)路由跳轉(zhuǎn)記錄的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對大家學(xué)習(xí)或者使用Vue.js具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-05-05

最新評論