亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

VUE多個下拉框?qū)崿F(xiàn)雙向聯(lián)動效果

 更新時間:2022年07月15日 15:49:34   作者:程序大視界  
這篇文章主要為大家詳細介紹了VUE多個下拉框?qū)崿F(xiàn)雙向聯(lián)動效果,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了VUE多個下拉框?qū)崿F(xiàn)雙向聯(lián)動的具體代碼,供大家參考,具體內(nèi)容如下

一、前言

在開發(fā)前端頁面的時候,常常需要寫下拉框,普通常見的下拉框有在頁面寫死固定值的下拉框,有通過調(diào)用后臺接口服務而獲取的值列表等。無論是原始的jsp頁面html頁面等,還是現(xiàn)在流行的vue angluar.js等,邏輯都是一樣。本文講解VUE頁面中,多個下拉框如何實現(xiàn)雙向聯(lián)動效果。

二、代碼示例

2.1 在vue頁面的<el-form 表單里填充兩個<el-col :span="12">選項,分別為選項A和選項B,如下所示:

<el-col :span="12">
? ? ? ? <el-form-item label="選項A" ?prop="A"> ? ? ? ? ? ?
? ? ? ? ? <el-select style="width: 100%;" @change="changeAList($event)"
? ? ? ? ? ? v-model="temp.A"
? ? ? ? ? ? filterable
? ? ? ? ? ? remote
? ? ? ? ? ? clearable
? ? ? ? ? ? placeholder="請選擇"
? ? ? ? ? ? :remote-method="getAMethod"
? ? ? ? ? ? :loading="loading">
? ? ? ? ? ? <el-option
? ? ? ? ? ? ? v-for="item in ListA"
? ? ? ? ? ? ? :key="item.value"
? ? ? ? ? ? ? :label="item.value"
? ? ? ? ? ? ? :value="item.label">
? ? ? ? ? ? </el-option>
? ? ? ? ? </el-select>
? ? ? ? </el-form-item>
? ? ? </el-col>
? ? ? <el-col :md="12" >
? ? ? ? <el-form-item label="選項B" ?prop="B"> ? ? ? ? ? ?
? ? ? ? ? <el-select style="width: 100%;" @change="changeBList($event)"
? ? ? ? ? ? v-model="temp.B"
? ? ? ? ? ? filterable
? ? ? ? ? ? remote
? ? ? ? ? ? clearable
? ? ? ? ? ? placeholder="請選擇"
? ? ? ? ? ? :remote-method="getBMethod"
? ? ? ? ? ? :loading="loading">
? ? ? ? ? ? <el-option
? ? ? ? ? ? ? v-for="item in ListB"
? ? ? ? ? ? ? :key="item.value"
? ? ? ? ? ? ? :label="item.value"
? ? ? ? ? ? ? :value="item.label">
? ? ? ? ? ? </el-option>
? ? ? ? ? </el-select>
? ? ? ? </el-form-item>
</el-col>

2.2 在data的return模塊定義兩個list集合,用于裝載選項A和選項B的數(shù)據(jù)list集

data() {
? ? return {
?
? ? ? ? ? ? ? ListA: [],
?
? ? ? ? ? ? ? ListB: [],
? ? ? ? }
}

2.3 在methods: 方法區(qū)定義下拉框選項加載從后臺接口服務獲取的方法。getAMethod用來加載A選項的下拉框內(nèi)容。getBMethod用來加載B選項的下拉框內(nèi)容。

getAMethod(temp) {
? ? ? ? XXAPI.getAValue(temp)
? ? ? ? .then(response => {
? ? ? ? ? if(response.data && response.status == 200){
? ? ? ? ? ? this.ListA= []
? ? ? ? ? ? var result = response.data.data.XX
? ? ? ? ? ? let jsonObj = JSON.parse(result);
? ? ? ? ? ? for (let k of Object.keys(jsonObj)) {
? ? ? ? ? ? ? this.ListA.push(
? ? ? ? ? ? ? ? {
? ? ? ? ? ? ? ? ? label: k,
? ? ? ? ? ? ? ? ? value: jsonObj[k].屬性A,
? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? )
? ? ? ? ? ? }
? ? ? ? ? }
? ? ? ? })
? ? ? },
? ? ? getBMethod(temp) {
? ? ? ? XXAPI.getDicValue2(temp)
? ? ? ? .then(response => {
? ? ? ? ? if(response.data && response.status == 200){
? ? ? ? ? ? this.ListB = []
? ? ? ? ? ? var result = response.data.data.XX
? ? ? ? ? ? let jsonObj = JSON.parse(result);
? ? ? ? ? ? for (let k of Object.keys(jsonObj)) {
? ? ? ? ? ? ? this.ListB .push(
? ? ? ? ? ? ? ? {
? ? ? ? ? ? ? ? ? label: k,
? ? ? ? ? ? ? ? ? value: jsonObj[k].屬性B,
? ? ? ? ? ? ? ? }
? ? ? ? ? ? ? )
? ? ? ? ? ? }
? ? ? ? ? }
? ? ? ? })
? ? ? },

上述步驟僅完成基本的框架搭建,也就是說后臺和前端的數(shù)據(jù)集合裝載以及接口服務調(diào)用用以獲取數(shù)據(jù)集合等。

2.4 實現(xiàn)聯(lián)動,大家都知道在vue的頁面中,想要實現(xiàn)多個<el-select 下拉框的值動態(tài)改變,必須要調(diào)用@change 函數(shù)。也就是圖1中已經(jīng)標注的:@change="changeAList($event) 和 @change="changeBList($event)

通過這2個方法即可實現(xiàn)兩個下拉框的雙向聯(lián)動效果。

同樣在methods:方法區(qū)定義方法:

changeBList(e){
? ? ? this.indexSelectB(e)
? ? },
? ?changeAList(e){
? ? ? this.indexSelectA(e)
? ? },
?
? ? ?indexSelectB(e){
? ? ? ? if(this.ListA == undefined || this.ListA .length <= 0){
? ? ? ? ? ? this.getAMethod(this.temp);
? ? ? ? }
? ? ? ? let i = 0;
? ? ? ? for (i = 0;i<this.ListA .length;i++) {
? ? ? ? ? if (this.ListA [i].label == e){
? ? ? ? ? ? this.temp.A= this.ListA [i].value;
? ? ? ? ? ? break
? ? ? ? ? }
? ? ? ? }
? ? ? },
? ? ? indexSelectA(e){
? ? ? ? if(this.ListB == undefined || this.ListB.length <= 0){
? ? ? ? ? ? this.getBMethod(this.temp);
? ? ? ? }
? ? ? ? let i = 0;
? ? ? ? for (i = 0;i<this.ListB.length;i++) {
? ? ? ? ? if (this.ListB[i].label == e){
? ? ? ? ? ? this.temp.B= this.ListB[i].value;
? ? ? ? ? ? break
? ? ? ? ? }
? ? ? ? }
? ? ? }

以上方法即可實現(xiàn)選項A和選項B兩個下拉框的雙向聯(lián)動。但是有個小缺陷,必須要輸入字符后才能加載出來數(shù)據(jù)。

這是因為沒有在頁面創(chuàng)建的時候,就把后臺的數(shù)據(jù)load出來,實現(xiàn)這個效果也很簡單,只需要在created模塊中調(diào)用兩個加載后臺接口服務的方法即可,如下:

created() {
? ? ...
? ? this.getAMethod(this.temp);
? ? this.getBMethod(this.temp);
? ? ...
? },

以上就是本文的全部內(nèi)容,希望對大家的學習有所幫助,也希望大家多多支持腳本之家。

相關文章

  • vue中使用axios post上傳頭像/圖片并實時顯示到頁面的方法

    vue中使用axios post上傳頭像/圖片并實時顯示到頁面的方法

    今天小編就為大家分享一篇vue中使用axios post上傳頭像/圖片并實時顯示到頁面的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-09-09
  • 改變vue請求過來的數(shù)據(jù)中的某一項值的方法(詳解)

    改變vue請求過來的數(shù)據(jù)中的某一項值的方法(詳解)

    下面小編就為大家分享一篇改變vue請求過來的數(shù)據(jù)中的某一項值的方法(詳解),具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-03-03
  • vue文件代碼縮進以及格式化代碼方式[自定義]

    vue文件代碼縮進以及格式化代碼方式[自定義]

    這篇文章主要介紹了vue文件代碼縮進以及格式化代碼方式[自定義],具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • 一篇超完整的Vue新手入門指導教程

    一篇超完整的Vue新手入門指導教程

    這篇文章主要給大家介紹了關于Vue入門的相關資料,是一篇超完整的Vue入門教程,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2020-11-11
  • 解讀resetFields()不生效的原因

    解讀resetFields()不生效的原因

    這篇文章主要介紹了解讀resetFields()不生效的原因,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-04-04
  • vscode中prettier和eslint換行縮進沖突的問題

    vscode中prettier和eslint換行縮進沖突的問題

    這篇文章主要介紹了vscode中prettier和eslint換行縮進沖突的問題及解決,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2023-10-10
  • Vue?2中實現(xiàn)CustomRef方式防抖節(jié)流

    Vue?2中實現(xiàn)CustomRef方式防抖節(jié)流

    這篇文章主要為大家介紹了Vue?2中實現(xiàn)CustomRef方式防抖節(jié)流示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-02-02
  • vue使用rem實現(xiàn) 移動端屏幕適配

    vue使用rem實現(xiàn) 移動端屏幕適配

    這篇文章主要介紹了vue使用rem實現(xiàn) 移動端屏幕適配的相關知識,通過實例代碼介紹了vue用rem布局的實現(xiàn)代碼,需要的朋友可以參考下
    2018-09-09
  • vue?Echarts實現(xiàn)儀表盤案例

    vue?Echarts實現(xiàn)儀表盤案例

    這篇文章主要為大家詳細介紹了vue?Echarts實現(xiàn)儀表盤案例,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • elementui?el-calendar日歷組件使用示例

    elementui?el-calendar日歷組件使用示例

    這篇文章主要為大家介紹了elementui?el-calendar日歷組件使用示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2023-12-12

最新評論