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

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

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

前言

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

實現(xiàn)過程

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

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

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

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

3.1點擊省下拉菜單獲取省份:

 主要技術點在于:通過調(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  /* 省*/
         /* 進行遍歷賦值*/
         /* 市區(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ū)劃樹進行初始化,主要是給選各個省份匹配其對應的市和縣級行政區(qū)。

接下來的操作就是點擊選擇省份就可以獲取其對應的 市級行政區(qū),點擊選擇市級下拉菜單就可以獲取其對應的縣級行政區(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)
                        }
                    })
                }
            },

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

總結(jié)

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

相關文章

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

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

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

    詳解在vue-cli中使用路由

    本篇文章主要介紹了詳解在vue-cli中使用路由,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    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問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • Vue的雙向數(shù)據(jù)綁定實現(xiàn)原理解析

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

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

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

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

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

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

    Vue EventBus自定義組件事件傳遞

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

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

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

    vue封裝組件js版基本步驟

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

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

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

最新評論