Vue中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)
}
参考大佬文章
更多推荐
已为社区贡献6条内容
所有评论(0)