TA的每日心情  | 开心 2021-12-13 21:45 | 
|---|
 
  签到天数: 15 天 [LV.4]偶尔看看III  
 | 
 
| 
 
 博客地址:https://ainyi.com/68  
最近遇到一个问题,在一个页面需要动态渲染页面内的表单,其中包括 checkbox 表单类型,并且使用 Element 组件 UI 时,此时 v-model 绑定的数据也是动态生成的  
例如: 
 定义的 data 的 form 里面是空对象,需要动态生成里面的 key - [code]export default {
 -   data() {
 -     return {
 -       form: {}
 -     }
 -   },
 - }
 
  复制代码 [/code]  
 
 
 从后端接口得到 checkList,这个就是动态生成的表单数据  
v-for 循环 checkList,得到 key,然后直接 v-model="form.key" 动态生成 form 里面的 key - [code]<el-form-item :label="item1.name+`:`" v-for="item1 in checkList" :key="item1.id">
 -   <el-checkbox-group v-model="form[`${item1.code}`]">
 -     <el-checkbox
 -       :label="item2.id"
 -       v-for="item2 in item1.values"
 -       :key="item2.id">
 -       {{ item2.value }}
 -     </el-checkbox>
 -   </el-checkbox-group>
 - </el-form-item>
 
  复制代码 [/code]  
问题来了  
当页面点击动态生成的 CheckBox 方框,会出现全选的情况,查看 vue 数据,显示如下: 
    
正常的情况 CheckBox 的绑定数据类型是数组形式  
那我在动态生成的时候,就它置为数组格式: - [code]this.checkList.forEach(item => {
 -   let key = item.code
 -   this.form[key] = []
 - })
 
  复制代码 [/code]  
但还是没用,会发现点击任何 CheckBox 都无法勾选  
解决  
这是 vue 的深入响应式原理,官方说法和解决方法:  
Vue 不允许在已经创建的实例上动态添加新的根级响应式属性 (root-level reactive property) 
 然而它可以使用 Vue.set(object, key, value) 方法将响应属性添加到嵌套的对象上  
现在明白了,可以使用 Vue.set 方法解决这个==深入式响应原理== - [code]this.checkList.forEach(item => {
 -   let key = item.code
 -   this.$set(this.form, key, [])
 - })
 
  复制代码 [/code]  
完美解决~  
博客地址:https://ainyi.com/68 |   
 
 
 
 |