我就废话不多说了,大家还是直接看代码吧~
<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的操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
- 三国志8重制版恶名怎么消除 恶名影响与消除方法介绍
- 模拟之声慢刻CD《柏林之声5》2019[原抓WAV+CUE]
- AlexandraSoumm-Parisestunefte(2024)[24Bit-96kHz]FLAC
- 李嘉《国语转调1》[天王唱片][WAV整轨]
- 不是哥们 这都能跑?网友展示用720显卡跑《黑神话》
- 玩家自制《黑神话:悟空》亢金星君3D动画 现代妆容绝美
- 大佬的审美冲击!《GTA6》环境设计师展示最新作品
- 纪晓君.2001-野火·春风【魔岩】【WAV+CUE】
- 汪峰.2005-怒放的生命【创盟音乐】【WAV+CUE】
- 群星.1995-坠入情网【宝丽金】【WAV+CUE】
- 群星《谁杀死了Hi-Fi音乐》涂鸦精品 [WAV+CUE][1G]
- 群星1998《宝丽金最精彩98》香港首版[WAV+CUE][1G]
- 汪峰《也许我可以无视死亡》星文[WAV+CUE][1G]
- 李嘉-1991《国语转调2》[天王唱片][WAV整轨]
- 蔡琴2008《金声回忆录101》6CD[环星唱片][WAV整轨]