Vue中input被赋值后,无法再修改编辑的问题及解决
input被赋值后,无法再修改编辑
我们直入主题
上面是我司的业务逻辑图,使用elementui框架,如图,请求数据赋值后,不仅有检测报错信息,而且还有无法修改编辑的问题。
起初以为是我的设置的对象问题,困扰我许久。
后来,翻阅了大佬的文章才了解。
<el-form ref="formInline" :inline="true" :rules="rules" :model="formInline" label-position="right" size="medium"> <el-form-item label="SIM卡号" prop="icsim"> <el-input v-model.number="formInline.icsim" maxlength="18" /> </el-form-item> <el-form-item label="ICCID码" prop="iccid"> <el-input v-model="formInline.iccid" /> </el-form-item> <el-form-item label="激活时间" prop="start"> <el-date-picker v-model="formInline.start" value-format="yyyy-MM-dd HH:mm:ss" style="width:200px" placeholder="选择日期"/> </el-form-item> <el-form-item label="服务到期时间" prop="end"> <el-date-picker v-model="formInline.end" value-format="yyyy-MM-dd HH:mm:ss" style="width:200px" placeholder="选择日期"/> </el-form-item> </el-form>
export default { name: 'formInline', data () { return { formInline: {} } }, methods: { // vue 请求数据 async getSimData(params) { const res = await simInfoByVid(params) const { sid, iccid, start, end, storage, icsim, vid } = res.data this.formInline.sid = sid this.formInline.iccid = iccid this.formInline.start = start this.formInline.end = end this.formInline.storage = storage this.formInline.icsim = icsim this.formInline.vid = vid } } }
上面的代码是我第一次写的代码,使用上面的方法,导致input框或者日期选择框无法再编辑。
根据官方文档定义:如果在实例创建之后添加新的属性到实例上,它不会触发视图更新
根据大佬的文章,总结了两个办法:
方法一
由此Vue实例创建时,formInline的属性名并未声明,因此Vue就无法对属性执行 getter/setter 转化过程,导致formInline属性不是响应式的,因此无法触发视图更新。
解决的方式有两种,第一种就是显示的声明formInline这个对象的属性,如:
data () { return { formInline: { sid: '', iccid: '', start: '', end: '', storage: '', icsim: '', vid: '' } }
方法二
使用Vue的全局API: $set()赋值:
async getSimData(params) { const res = await simInfoByVid(params) const { sid, iccid, start, end, storage, icsim, vid } = res.data this.$set(this.formInline, 'sid', sid) this.$set(this.formInline, 'iccid', iccid) this.$set(this.formInline, 'start', start) this.$set(this.formInline, 'end', end) this.$set(this.formInline, 'storage', storage) this.$set(this.formInline, 'icsim', icsim) }
vue综合问题归纳input框赋值后不能进行编辑
项目场景
项目场景:前端实现查看编辑功能的时候会出现, input框赋值后input框不能进行编辑,编辑之后自动取消,验证无法进行取消
问题描述
数据代码:
<el-textarea v-model="drawerForm.msg" placeholder="请输入功能描述" :rows="3" allowClear ></el-textarea>
js:
export default { name: 'drawerForm', data () { return { drawerForm: {} } }, methods: { handleEditHelloForm () { // 模拟编辑功能需要数据回显 this.helloForm.msg = 'hello 我是drawerForm中的msg值' } } }
原因分析
- 空input框进行赋值后,不存在setter和getter方法,导致无法实现双向绑定
- 由此Vue实例创建时,drawerForm.属性名并未声明,因此Vue就无法对属性执行 getter/setter 转化过程,导致drawerForm属性不是响应式的,因此无法触发视图更新。
解决方案
第一种就是显示的声明drawerForm这个对象的属性,如:
data () { return { drawerForm: { msg:"" } } },
使用vue的全局方法: this.$set(data, property, value)
data为要修改的对象,property为要添加的属性,value就是这个属性的值 handleEditHelloForm () { // 模拟编辑功能需要数据回显 Vue.set(this.helloForm,'msg', 'hello 我是drawerForm中的msg') }
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
vue3-print-nb实现页面打印(含分页打印)示例代码
大多数后台系统中都存在打印的需求,在有打印需求时,对前端来说当然是直接打印页面更容易,下面这篇文章主要给大家介绍了关于vue3-print-nb实现页面打印(含分页打印)的相关资料,需要的朋友可以参考下2024-01-01Vue数据与事件绑定以及Class和Style的绑定详细讲解
这篇文章主要介绍了Vue数据与事件绑定以及Class和Style的绑定,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习吧2023-01-01详解Vue-cli中的静态资源管理(src/assets和static/的区别)
这篇文章主要介绍了Vue-cli中的静态资源管理(src/assets和static/的区别,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧2018-06-06
最新评论