在Vue中使用Select选择器拼接label的操作


Posted in Javascript onOctober 22, 2020

我就废话不多说了,大家还是直接看代码吧~

<el-form-item label="货道商品" prop="productid">
          <el-select v-model="form.productid" filterable placeholder="请选择" @change="changeselect">
            <el-option v-for="item in myproducts"
                  :key="item.Id"
                  :label="`${item.Name}/${item.Brand}/${item.Type}/${item.Spec}`"
                  :value="item.Id">
            </el-option>
          </el-select>
        </el-form-item>

正常使用方法:

:label=“item.label”

多个字段拼接:

:label="${item.Name}/${item.Brand}/${item.Type}/${item.Spec}"

补充知识:element el-select 动态创建绑定属性,视图不更新之-连环填坑

项目需求是这样的:

1. 在 a组件通过操作页面,请求拿到需要的data,然后将数据存在vuex 中,数据结构为多层嵌套结构大概如下

ceshi:[
  {
   values:[
    {
     value:[
      {id:1,label:'哈哈1'},
      {id:2,label:'哈哈2'},
      {id:3,label:'哈哈3'}
     ]
    },
    {
     value:[
      {id:4,label:'哈哈4'},
      {id:5,label:'哈哈5'},
      {id:6,label:'哈哈6'}
     ]
    }
   ]
  }
 ]

在组件中通过获取vuex中的数据ceshi为数据源,

computed: {
  ...mapGetters(['ceshi'])
 },

然后在b组件中动态渲染数据,因为我需要动态绑定属性所以我在computed中创建动态变量结构

//数据渲染
  <div v-for="(x1,index1) in ceshi" :key="index1+'1'">
   <div v-for="(x2,index2) in x1.values" :key="index2+'2'">
     <el-select placeholder="请选择" v-model="form[index1].values[index2].value"> //动态绑定属性
      <el-option
       v-for="item in x2.value"
       :key="item.id"
       :label="item.label"
       :value="item.id">
      </el-option>
     </el-select>
   </div>
  </div>
//  

computed: {
  ...mapGetters(['ceshi']),  
   form(){   
    return this.ceshi.map((val,index) => {
     let values = val.values.map((val,index) => {
      let json={value:""}
      return json
     })
     let ojson = {values};
     return ojson
    })
   }  
 }

发现数据绑定成功,选择框变化数据也会变化,但是页面不改变,视图没有更新,通过在select代码中加入$set方法,也并没有用,视图同样没有更新;查看文档发现发现computer默认没有双向绑定 ,默认为getter 需要自己写setter函数,但是我发现,因为我的动态数据是我通过vuex 中的数据得来的,我也并没有定义其他的data,所以无法使用setter,于是进行修改如下

data() {
  return {
   form:[]
 },
created () {
   this.ceshi.forEach((val,index) => {
    let values = val.values.map((val,index) => {
     let json={value:""}
     return json
    })
    let ojson = {values};
    this.form.push(ojson)
   })  
 }

结果报错,分析原因应该是,我并没有在a组件操作获取数据,但这个时候created函数运行于是报错了,修改逻辑为通过watch 监听ceshi 数据变化

ceshi: {
   handler(newValue,oldValue) {
    this.ceshi.forEach((val,index) => {
      let values = val.values.map((val,index) => {
       let json={value:""}
       return json
      })
      let ojson = {values};
      this.form.push(ojson)
     })
   },
   deep: true
  }

再看效果,发现解决了,记录如下,希望能帮助到您!

以上这篇在Vue中使用Select选择器拼接label的操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
addRule在firefox下的兼容写法
Nov 30 Javascript
JavaScript进阶教程(第四课第一部分)
Apr 05 Javascript
匹配任意字符的正则表达式写法
Apr 29 Javascript
Eclipse引入jquery报错如何解决
Dec 01 Javascript
jQuery实现标签页效果实战(4)
Feb 08 Javascript
ES6中Generator与异步操作实例分析
Mar 31 Javascript
webpack+vuex+axios 跨域请求数据的示例代码
Mar 06 Javascript
基于打包工具Webpack进行项目开发实例
May 29 Javascript
vue-cli项目无法用本机IP访问的解决方法
Sep 20 Javascript
小程序实现列表多个批量倒计时
Jan 29 Javascript
JS中注入eval, Function等系统函数截获动态代码
Apr 03 Javascript
微信小程序商品详情页底部弹出框
Nov 22 Javascript
JavaScript 中判断变量是否为数字的示例代码
Oct 22 #Javascript
关于vue属性使用和不使用冒号的区别说明
Oct 22 #Javascript
jquery实现抽奖功能
Oct 22 #jQuery
Vue实现简单的留言板
Oct 23 #Javascript
Vue+Bootstrap收藏(点赞)功能逻辑与具体实现
Oct 22 #Javascript
JavaScript实现简易计算器小功能
Oct 22 #Javascript
vue实现简单加法计算器
Oct 22 #Javascript
You might like
Windows7下PHP开发环境安装配置图文方法
2010/05/20 PHP
PHP封装的多文件上传类实例与用法详解
2017/02/07 PHP
jquery事件重复绑定的快速解决方法
2014/01/03 Javascript
微信小程序 MINA文件结构
2016/10/17 Javascript
原生JS实现匀速图片轮播动画
2016/10/18 Javascript
基于JQuery及AJAX实现名人名言随机生成器
2017/02/10 Javascript
Bootstrap一款超好用的前端框架
2017/09/25 Javascript
mui框架移动开发初体验详解
2017/10/11 Javascript
ant design实现圈选功能
2019/12/17 Javascript
前端深入理解Typescript泛型概念
2020/03/09 Javascript
JavaScript实现移动端带transition动画的轮播效果
2020/03/24 Javascript
Vue如何将页面导出成PDF文件
2020/08/17 Javascript
Python使用scrapy采集数据时为每个请求随机分配user-agent的方法
2015/04/08 Python
Pycharm学习教程(3) 代码运行调试
2017/05/03 Python
Python2.7 实现引入自己写的类方法
2018/04/29 Python
python中将正则过滤的内容输出写入到文件中的实例
2018/10/21 Python
python使用PIL实现多张图片垂直合并
2019/01/15 Python
python分割一个文本为多个文本的方法
2019/07/22 Python
python中with用法讲解
2020/02/07 Python
基于python实现对文件进行切分行
2020/04/26 Python
用python发送微信消息
2020/12/21 Python
俄罗斯披萨、寿司和面食送货到家服务:2 Берега
2019/12/15 全球购物
大学生工作推荐信范文
2013/12/02 职场文书
2014年健康教育实施方案
2014/02/17 职场文书
2014年教师节寄语
2014/04/03 职场文书
咖啡店创业计划书范文
2014/09/15 职场文书
客房服务员岗位职责
2015/02/09 职场文书
个人党性分析总结
2015/03/05 职场文书
2015年美容师个人工作总结
2015/10/14 职场文书
互联网的下一个风口:新的独角兽将诞生
2019/08/02 职场文书
SpringBoot 拦截器妙用你真的了解吗
2021/07/01 Java/Android
MySQL 5.7常见数据类型
2021/07/15 MySQL
CSS3 Tab动画实例之背景切换动态效果
2021/08/23 HTML / CSS
python中数组和列表的简单实例
2022/03/25 Python
基于Redis6.2.6版本部署Redis Cluster集群的问题
2022/04/01 Redis
python如何查找列表中元素的位置
2022/05/30 Python