vue 下拉框回显映射

vue 下拉框回显映射

大家在做项目的时候,应该非常的容易遇到,下拉框的回显问题吧? 包括单选框,复选框,级联框的回显
如果使用组件的话, 比如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
},  
// 输出:   ['双皮奶','龙须面']

级联框

后端返回的:  
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
},  
// 输出:   ['指南','设计原则','反馈']

欢迎指正,再会

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值