vue+elementUI下拉框回顯問(wèn)題及解決方式
vue elementUI下拉框回顯問(wèn)題
在開(kāi)發(fā)過(guò)程中,總會(huì)做到修改功能,但是在修改回顯的時(shí)候,發(fā)現(xiàn)下拉框始終回顯的是id而不是文本
下面看案例
正確回顯格式應(yīng)該是這樣

而回顯的確實(shí)這個(gè)值的id

原因是因?yàn)樵诮oselect復(fù)制的時(shí)候沒(méi)有重新渲染,一開(kāi)始我的編輯回顯方法是這樣
// 編輯回顯
edit() {
// 通過(guò)選中id查詢信息
axios.get('/xxx/xxx/id', {
params: { id: this.selectedRows[0].ID }
}).then((reponse) => {
// 然后直接賦值到表單上
this.recordFrom = reponse.data.data[0]
})
// 打開(kāi)表單頁(yè)面
this.editRecordDialog = true
}
直接將查詢的數(shù)據(jù)賦值到表單中,只會(huì)賦值返回回來(lái)的值,如果v-model綁定的值是id,則只會(huì)顯示id,如果綁定的值是name,則只會(huì)顯示name。
所以,給表單賦值的時(shí)候需要重新渲染一下下拉框
給賦值之后下面增加了一個(gè)查詢下拉框的方法
// 編輯回顯
edit() {
// 通過(guò)選中id查詢信息
axios.get('/xxx/xxx/id', {
params: { id: this.selectedRows[0].ID }
}).then((reponse) => {
// 然后直接賦值到表單上
this.recordFrom = reponse.data.data[0]
})
// 重新查詢下拉框方法
this.getNumber2()
// 打開(kāi)表單頁(yè)面
this.editRecordDialog = true
}
查詢方法代碼:
// 查詢版本號(hào)到下拉框
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="版本號(hào)" prop="verID"> <el-select class="select-type" v-model="recordFrom.verID" placeholder="請(qǐng)選擇版本號(hào)"> <el-option v-for="item in options5" :key="item.ID" :label="item.versionNumber" :value="item.ID"> </el-option> </el-select> </el-form-item>
重新渲染之后,就可以正常回顯啦!
vue下拉框回顯映射
大家在做項(xiàng)目的時(shí)候,應(yīng)該非常的容易遇到,下拉框的回顯問(wèn)題吧?包括單選框,復(fù)選框,級(jí)聯(lián)框的回顯
如果使用組件的話,比如element-UI,他們內(nèi)部有自己的映射方法,將id傳過(guò)去自己能回顯到下拉框中,還是挺方便的,可是如果給一個(gè)id 讓你映射出他所對(duì)應(yīng)的名字,你要怎么辦呢?讓我們一起來(lái)看看吧?
單選框
- 后端返回的:
value: '選項(xiàng)1'
- 下拉數(shù)組:
options: [{
? ? ? ? ? value: '選項(xiàng)1',
? ? ? ? ? label: '黃金糕'
? ? ? ? }, {
? ? ? ? ? value: '選項(xiàng)2',
? ? ? ? ? label: '雙皮奶'
? ? ? ? }, {
? ? ? ? ? value: '選項(xiàng)3',
? ? ? ? ? label: '蚵仔煎'
? ? ? ? }, {
? ? ? ? ? value: '選項(xiàng)4',
? ? ? ? ? label: '龍須面'
? ? ? ? }, {
? ? ? ? ? value: '選項(xiàng)5',
? ? ? ? ? label: '北京烤鴨'
? ? ? ? }],
// 映射方法
formatterName(options, value) {
? let obj = {}
? obj = options.find(item => item.value=== value)
? return obj.label
}, ?
// 輸出: ? 黃金糕 ? ?多選框
- 后端返回的:
value: ['選項(xiàng)2,選項(xiàng)4']
- 下拉數(shù)組:
options: [{
? ? ? ? ? value: '選項(xiàng)1',
? ? ? ? ? label: '黃金糕'
? ? ? ? }, {
? ? ? ? ? value: '選項(xiàng)2',
? ? ? ? ? label: '雙皮奶'
? ? ? ? }, {
? ? ? ? ? value: '選項(xiàng)3',
? ? ? ? ? label: '蚵仔煎'
? ? ? ? }, {
? ? ? ? ? value: '選項(xiàng)4',
? ? ? ? ? label: '龍須面'
? ? ? ? }, {
? ? ? ? ? value: '選項(xiàng)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
}, ?
// 輸出: ? ['雙皮奶','龍須面']級(jí)聯(lián)框
- 后端返回的:
value: ['zhinan','shejiyuanze','fankui']
- 下拉數(shù)組:
options: [{
? value: 'zhinan',
? label: '指南',
? children: [{
? ? value: 'shejiyuanze',
? ? label: '設(shè)計(jì)原則',
? ? 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
}, ?
// 輸出: ? ['指南','設(shè)計(jì)原則','反饋']總結(jié)
以上為個(gè)人經(jīng)驗(yàn),希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。
相關(guān)文章
Vue項(xiàng)目通過(guò)network的ip地址訪問(wèn)注意事項(xiàng)及說(shuō)明
這篇文章主要介紹了Vue項(xiàng)目通過(guò)network的ip地址訪問(wèn)注意事項(xiàng)及說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-09-09
關(guān)于Ant-Design-Vue快速上手指南+排坑
這篇文章主要介紹了關(guān)于Ant-Design-Vue快速上手指南+排坑,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-06-06
解決vant的Toast組件時(shí)提示not defined的問(wèn)題
這篇文章主要介紹了解決vant的Toast組件時(shí)提示not defined的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧2020-11-11
vue項(xiàng)目使用node連接數(shù)據(jù)庫(kù)的方法(前后端分離)
這篇文章主要介紹了vue項(xiàng)目使用node連接數(shù)據(jù)庫(kù)(前后端分離),本文結(jié)合示例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2022-12-12
Vue3新特性之在Composition API中使用CSS Modules
這篇文章主要介紹了Vue3新特性之在Composition API中使用CSS Modules,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-07-07
關(guān)于vue設(shè)置環(huán)境變量全流程
這篇文章主要介紹了關(guān)于vue設(shè)置環(huán)境變量全流程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03

