在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 相关文章推荐
JQuery 前台切换网站的样式实现
Jun 22 Javascript
jQuery Lightbox 图片展示插件使用说明
Apr 25 Javascript
jquery实现鼠标滑过小图时显示大图的方法
Jan 14 Javascript
js自制图片放大镜功能
Jan 24 Javascript
解决option标签selected=&quot;selected&quot;属性失效的问题
Nov 06 Javascript
Vue监听一个数组id是否与另一个数组id相同的方法
Sep 26 Javascript
详解关于html,css,js三者的加载顺序问题
Apr 10 Javascript
this.$toast() 了解一下?
Apr 18 Javascript
微信小程序自定义可滑动顶部TabBar选项卡实现页面切换功能示例
May 14 Javascript
解决vue单页面应用中动态修改title问题
Jun 09 Javascript
前端Vue项目详解--初始化及导航栏
Jun 24 Javascript
JavaScript算法学习之冒泡排序和选择排序
Nov 02 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
php学习之变量的使用
2011/05/29 PHP
PHP中全面阻止SQL注入式攻击分析小结
2012/01/30 PHP
PHP使用PHPMailer发送邮件的简单使用方法
2013/11/12 PHP
PHP根据两点间的经纬度计算距离
2014/10/31 PHP
php上传中文文件名乱码问题处理方案
2015/02/03 PHP
PHP laravel中的多对多关系实例详解
2017/06/07 PHP
Laravel框架创建路由的方法详解
2019/09/04 PHP
用Javascript实现Sleep暂停功能代码
2010/09/03 Javascript
JavaScript利用正则表达式去除日期中的-
2014/06/09 Javascript
JavaScript实现穷举排列(permutation)算法谜题解答
2014/12/29 Javascript
jQuery中$.click()无效问题分析
2015/01/29 Javascript
一看就懂:jsonp详解
2015/06/01 Javascript
jQuery实现的经典滑动门效果
2015/09/22 Javascript
javascript中的3种继承实现方法
2016/01/27 Javascript
AngularJS 自定义指令详解及示例代码
2016/08/17 Javascript
js防阻塞加载的实现方法
2016/09/09 Javascript
connection reset by peer问题总结及解决方案
2016/10/21 Javascript
JavaScript的事件机制详解
2017/01/17 Javascript
详解使用React.memo()来优化函数组件的性能
2019/03/19 Javascript
解决Vue动态加载本地图片问题
2019/10/09 Javascript
Node.js API详解之 dns模块用法实例分析
2020/05/15 Javascript
基于javascript原生判断DOM是否加载完毕
2020/10/14 Javascript
python解析json实例方法
2013/11/19 Python
python设置检查点简单实现代码
2014/07/01 Python
简单介绍Python的Django框架的dj-scaffold项目
2015/05/30 Python
python目录与文件名操作例子
2016/08/28 Python
python使用turtle库绘制时钟
2020/03/25 Python
用Python shell简化开发
2018/08/08 Python
Python实现正则表达式匹配任意的邮箱方法
2018/12/20 Python
python实现按首字母分类查找功能
2019/10/31 Python
Keras 在fit_generator训练方式中加入图像random_crop操作
2020/07/03 Python
意大利在线眼镜精品店:Ottica Lipari
2019/11/11 全球购物
后天观后感
2015/06/08 职场文书
新娘婚礼答谢词
2015/09/29 职场文书
frg-100简单操作(设置)说明
2022/04/05 无线电
Win11自动黑屏怎么办 Win11自动黑屏设置教程
2022/07/15 数码科技