avue行编辑el-select选择数据后未回写问题

排查问题发现v-model绑定值是变化的,刷新页面下次点击编辑可以回写上次选中的内容,说明只是vue没有监听到其变化,未刷新导致

1 常用解决方法:
使用vue中带的this.$set()方法去更新内容,发现仍然不可以

2 使用change方法手动更新表单内容,发现也不能

部分代码:
HTML:

<el-select v-model=“otherForm.departHour” placeholder=“请选择发车时段” @change=“val => onDepartHourChange(val, otherForm, row, index)”>


JS:
data() {
return {
dicts: {
departHour: [] // 发车时段
},
otherForm: {
classPlanId: null, // 行发车时段绑定的id,其表示当前的发车时段
departHour: ‘’ // 用于做数据回写label
}
}
},
onDepartHourChange(val, form) {
this. s e t ( f o r m , ′ c l a s s P l a n I d ′ , v a l . v a l u e ) / / 响应式加载,数组、对象属性中赋值最好使用 set(form, 'classPlanId', val.value) // 响应式加载,数组、对象属性中赋值最好使用 set(form,classPlanId,val.value)//响应式加载,数组、对象属性中赋值最好使用set进行赋值
this.$set(form, ‘departHour’, val.label)
},

最终解决方法:在HTML模板中加入了 slot-scope=“{ row, index }”

最后效果图:
在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
您可以通过以下步骤使用 el-select 组件来获取数据: 1. 首先,确保您已经正确引入了 Element UI 库,并在您的项目中注册了 el-select 组件。 2. 在您的 Vue 组件中,定义一个数据属性用于存储选择的值。例如,您可以在 data 中添加一个名为 selectedValue 的属性: ```js data() { return { selectedValue: '' } } ``` 3. 在 el-select 组件中,使用 v-model 指令绑定选中的值到 selectedValue: ```html <el-select v-model="selectedValue"> <!-- 在这里添加 el-option 标签以提供选项 --> </el-select> ``` 4. 在 el-select 组件内添加 el-option 标签作为选项。您可以通过 v-for 指令循环渲染选项列表,并为每个选项提供一个 value 属性: ```html <el-select v-model="selectedValue"> <el-option v-for="option in options" :key="option.value" :value="option.value">{{ option.label }}</el-option> </el-select> ``` 5. 在您的 Vue 组件中定义 options 数组,以提供选项的列表。您可以在 created 钩子或从后端接口获取数据后进赋值: ```js data() { return { selectedValue: '', options: [] } }, created() { // 示例:从后端接口获取数据并赋值给 options 数组 // 使用 axios 或其他库发送请求获取数据 // 将获取到的数据赋值给 options 数组 // this.options = response.data } ``` 这样,当用户选择一个选项时,selectedValue 属性会更新为相应的选项值。您可以通过访问 selectedValue 属性来获取用户选择的值。 请注意,这只是基本的示例,具体实现可能会根据您的项目需求和数据来源而有所不同。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值