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

vue+elementUI下拉框回顯問題及解決方式

 更新時間:2023年02月23日 17:15:19   作者:UnIQUE Eason  
這篇文章主要介紹了vue+elementUI下拉框回顯問題及解決方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教

vue elementUI下拉框回顯問題

在開發(fā)過程中,總會做到修改功能,但是在修改回顯的時候,發(fā)現(xiàn)下拉框始終回顯的是id而不是文本

下面看案例

正確回顯格式應該是這樣

正確回顯格式應該是這樣

而回顯的確實這個值的id

原因是因為在給select復制的時候沒有重新渲染,一開始我的編輯回顯方法是這樣

// 編輯回顯
    edit() {
    	// 通過選中id查詢信息
      axios.get('/xxx/xxx/id', {
          params: { id: this.selectedRows[0].ID }
        }).then((reponse) => {
        // 然后直接賦值到表單上
          this.recordFrom = reponse.data.data[0]
        })
	   // 打開表單頁面
      this.editRecordDialog = true
    }

直接將查詢的數據賦值到表單中,只會賦值返回回來的值,如果v-model綁定的值是id,則只會顯示id,如果綁定的值是name,則只會顯示name。

所以,給表單賦值的時候需要重新渲染一下下拉框

給賦值之后下面增加了一個查詢下拉框的方法

// 編輯回顯
    edit() {
    	// 通過選中id查詢信息
      axios.get('/xxx/xxx/id', {
          params: { id: this.selectedRows[0].ID }
        }).then((reponse) => {
        // 然后直接賦值到表單上
          this.recordFrom = reponse.data.data[0]
        })
       // 重新查詢下拉框方法
       this.getNumber2()
	   // 打開表單頁面
      this.editRecordDialog = true
    }

查詢方法代碼:

// 查詢版本號到下拉框
    getNumber2() {
      axios.get('xxx/xxx/number', { 
      params: { id: this.proNameSelect } })
      .then((reponse) => {
        var obj = reponse.data.data
        for (var i = 0; i < obj.length; i++) {
          this.options5.push({ value: obj[i].ID, label: obj[i].versionNumber })
        }
      })
    }

這里附上下拉框的代碼:

<el-form-item label="版本號" prop="verID">
 <el-select class="select-type" v-model="recordFrom.verID" placeholder="請選擇版本號">
  <el-option v-for="item in options5" :key="item.ID" :label="item.versionNumber" :value="item.ID"> </el-option>
 </el-select>
</el-form-item>

重新渲染之后,就可以正常回顯啦!

vue下拉框回顯映射

大家在做項目的時候,應該非常的容易遇到,下拉框的回顯問題吧?包括單選框,復選框,級聯(lián)框的回顯

如果使用組件的話,比如element-UI,他們內部有自己的映射方法,將id傳過去自己能回顯到下拉框中,還是挺方便的,可是如果給一個id 讓你映射出他所對應的名字,你要怎么辦呢?讓我們一起來看看吧?

單選框

  • 后端返回的:
value: '選項1'
  • 下拉數組:
options: [{
? ? ? ? ? value: '選項1',
? ? ? ? ? label: '黃金糕'
? ? ? ? }, {
? ? ? ? ? value: '選項2',
? ? ? ? ? label: '雙皮奶'
? ? ? ? }, {
? ? ? ? ? value: '選項3',
? ? ? ? ? label: '蚵仔煎'
? ? ? ? }, {
? ? ? ? ? value: '選項4',
? ? ? ? ? label: '龍須面'
? ? ? ? }, {
? ? ? ? ? value: '選項5',
? ? ? ? ? label: '北京烤鴨'
? ? ? ? }],
// 映射方法
formatterName(options, value) {
? let obj = {}
? obj = options.find(item => item.value=== value)
? return obj.label
}, ?
// 輸出: ? 黃金糕 ? ?

多選框

  • 后端返回的:
value: ['選項2,選項4']
  • 下拉數組:
options: [{
? ? ? ? ? value: '選項1',
? ? ? ? ? label: '黃金糕'
? ? ? ? }, {
? ? ? ? ? value: '選項2',
? ? ? ? ? label: '雙皮奶'
? ? ? ? }, {
? ? ? ? ? value: '選項3',
? ? ? ? ? label: '蚵仔煎'
? ? ? ? }, {
? ? ? ? ? value: '選項4',
? ? ? ? ? label: '龍須面'
? ? ? ? }, {
? ? ? ? ? value: '選項5',
? ? ? ? ? label: '北京烤鴨'
? ? ? ? }],
// 映射方法
formatterName(options, value, idArr = []) {
? if (typeof options=== 'object') {
? ? ?for (let i = 0; value[i] !== undefined; i++) {
? ? ? ?for (let j = 0; options[j] !== undefined; j++) {
? ? ? ? ?if (value[i] === options[j].value) {
? ? ? ? ? ?idArr.push(options[j].label)
? ? ? ? ?}
? ? ? ?}
? ? ?}
? ?}
? ?return idArr
}, ?
// 輸出: ? ['雙皮奶','龍須面']

級聯(lián)框

  • 后端返回的:
value: ['zhinan','shejiyuanze','fankui']
  • 下拉數組:
options: [{
? value: 'zhinan',
? label: '指南',
? children: [{
? ? value: 'shejiyuanze',
? ? label: '設計原則',
? ? children: [{
? ? ? value: 'yizhi',
? ? ? label: '一致'
? ? }, {
? ? ? value: 'fankui',
? ? ? label: '反饋'
? ? }, {
? ? ? value: 'xiaolv',
? ? ? label: '效率'
? ? }, {
? ? ? value: 'kekong',
? ? ? label: '可控'
? ? }]
? }]
// 映射方法
formatterName(options, value, idArr = []) {
? if (typeof options === 'object') {
? ? for (let i = 0; value[i] !== undefined; i++) {
? ? ? for (let j = 0; options[j] !== undefined; j++) {
? ? ? ? if (value[i] === options[j].value) {
? ? ? ? ? idArr.push(options[j].label)
? ? ? ? }
? ? ? }
? ? }
? ? for (let i = 0; options[i] !== undefined; i++) {
? ? ? this.formatterName(options[i].children, value, idArr)
? ? }
? }
? return idArr
}, ?
// 輸出: ? ['指南','設計原則','反饋']

總結

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • vue better-scroll插件使用詳解

    vue better-scroll插件使用詳解

    本篇文章主要介紹了vue better-scroll插件使用詳解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-01-01
  • Vue之data定義的三種方式及區(qū)別說明

    Vue之data定義的三種方式及區(qū)別說明

    這篇文章主要介紹了Vue之data定義的三種方式及區(qū)別說明,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-03-03
  • vue3項目中配置sass,vite報錯Undefined mixin問題

    vue3項目中配置sass,vite報錯Undefined mixin問題

    這篇文章主要介紹了vue3項目中配置sass,vite報錯Undefined mixin問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-02-02
  • vue項目回到頂部的兩種超簡單實現(xiàn)方法

    vue項目回到頂部的兩種超簡單實現(xiàn)方法

    這篇文章主要給大家介紹了關于vue項目回到頂部的兩種超簡單實現(xiàn)方法,?頁面切換回到頂部是一個很常見的功能,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2023-10-10
  • vue中getters的使用與四個map方法的使用方式

    vue中getters的使用與四個map方法的使用方式

    這篇文章主要介紹了vue中getters的使用與四個map方法的使用方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教
    2024-01-01
  • Vue項目環(huán)境搭建詳細總結

    Vue項目環(huán)境搭建詳細總結

    這篇文章主要為大家介紹了Vue項目環(huán)境搭建總結篇,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2019-09-09
  • Vue.js使用this.$confirm換行顯示提示信息實例

    Vue.js使用this.$confirm換行顯示提示信息實例

    在編寫Web應用時,實現(xiàn)多行文本顯示通常需要用到HTML標簽或JavaScript特定函數,本文介紹了如何使用JavaScript的$createElement函數來創(chuàng)建多行文本顯示,$createElement可以創(chuàng)建任何HTML標簽,使得在JavaScript中控制HTML輸出更加靈活,通過簡單的代碼示例
    2024-10-10
  • 在Vue中使用icon 字體圖標的方法

    在Vue中使用icon 字體圖標的方法

    這篇文章主要介紹了在Vue中使用icon 字體圖標的方法,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-06-06
  • Vue.js中v-on指令的用法介紹

    Vue.js中v-on指令的用法介紹

    這篇文章介紹了Vue.js中v-on指令的用法,文中通過示例代碼介紹的非常詳細。對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-03-03
  • Vue2.x中的父子組件相互通信的實現(xiàn)方法

    Vue2.x中的父子組件相互通信的實現(xiàn)方法

    這篇文章主要介紹了Vue2.x中的父子組件相互通信,需要的朋友可以參考下
    2017-05-05

最新評論