国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

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

瀏覽:87日期:2022-06-01 18:29:52
目錄
  • vue elementUI下拉框回顯問題
    • 正確回顯格式應(yīng)該是這樣
    • 而回顯的確實(shí)這個(gè)值的id
  • vue下拉框回顯映射
    • 單選框
    • 多選框
    • 級(jí)聯(lián)框
  • 總結(jié)

    vue elementUI下拉框回顯問題

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

    下面看案例

    正確回顯格式應(yīng)該是這樣

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

    原因是因?yàn)樵诮oselect復(fù)制的時(shí)候沒有重新渲染,一開始我的編輯回顯方法是這樣

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

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

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

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

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

    查詢方法代碼:

    // 查詢版本號(hào)到下拉框    getNumber2() {      axios.get("xxx/xxx/number", {       params: { id: this.proNameSelect } })      .then((reponse) => {var obj = reponse.data.datafor (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 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)該非常的容易遇到,下拉框的回顯問題吧?包括單選框,復(fù)選框,級(jí)聯(lián)框的回顯

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

    單選框

    • 后端返回的:
    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è)參考,也希望大家多多支持。

    標(biāo)簽: JavaScript
    相關(guān)文章:
    主站蜘蛛池模板: 国产精品美女一区二区 | 久久亚洲国产精品一区二区 | 日韩一区二区三区视频 | 欧美一区视频在线 | 亚洲国产成a人v在线 | 特黄特色大片免费播放路01 | 乱码一区 | 日本最色视频 | 手机看片精品国产福利盒子 | 国产成人系列 | 国自产精品手机在线视频香蕉 | 九九九热视频 | 99国产福利视频在线观看 | 成人高清视频免费观看 | 成人自拍小视频 | 日韩天天摸天天澡天天爽视频 | 久草免费福利 | 香蕉久久网站 | 99福利资源久久福利资源 | 性色a v 一区 | 在线不卡一区二区三区日韩 | 性a视频 | 欧美怡红院免费全视频 | 成人亚洲欧美日韩中文字幕 | 2021国产精品一区二区在线 | 手机看片久久青草福利盒子 | 成年人网站黄 | 久久精品中文字幕免费 | 久9青青cao精品视频在线 | 亚洲美女视频网站 | 国产深夜福利视频在线播放 | 国产亚洲精品久久久久久久久激情 | 欧美猛交xxxx免费看 | 久久欧美精品 | 国内精品2020情侣视频 | 中文无线乱码二三四区 | 午夜精品视频在线观看美女 | 黄色美女毛片 | 国产精品特黄一级国产大片 | 香港三级日本三级三级人妇 | 日韩欧美精品一区二区三区 |