解決 Vue 動態生成 el-checkbox 點擊沒法賦值問題

博客地址:https://ainyi.com/68html

最近遇到一個問題,在一個頁面須要動態渲染頁面內的表單,其中包括 checkbox 表單類型,而且使用 Element 組件 UI 時,此時 v-model 綁定的數據也是動態生成的vue

例如:
定義的 data 的 form 裏面是空對象,須要動態生成裏面的 keyreact

export default {
  data() {
    return {
      form: {}
    }
  },
}



從後端接口獲得 checkList,這個就是動態生成的表單數據後端

v-for 循環 checkList,獲得 key,而後直接 v-model="form.key" 動態生成 form 裏面的 key數組

<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>

問題來了

當頁面點擊動態生成的 CheckBox 方框,會出現全選的狀況,查看 vue 數據,顯示以下:
this

正常的狀況 CheckBox 的綁定數據類型是數組形式code

那我在動態生成的時候,就它置爲數組格式:orm

this.checkList.forEach(item => {
  let key = item.code
  this.form[key] = []
})

但仍是沒用,會發現點擊任何 CheckBox 都沒法勾選htm

解決

這是 vue 的深刻響應式原理,官方說法和解決方法:對象

Vue 不容許在已經建立的實例上動態添加新的根級響應式屬性 (root-level reactive property)
然而它能夠使用 Vue.set(object, key, value) 方法將響應屬性添加到嵌套的對象上

如今明白了,能夠使用 Vue.set 方法解決這個==深刻式響應原理==

this.checkList.forEach(item => {
  let key = item.code
  this.$set(this.form, key, [])
})

完美解決~

博客地址:https://ainyi.com/68

相關文章
相關標籤/搜索