国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 開發 > JS > 正文

Vue動態生成el-checkbox點擊無法賦值的解決方法

2024-05-06 16:48:23
字體:
來源:轉載
供稿:網友

前言

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

例如:

定義的 data 的 form 里面是空對象,需要動態生成里面的 key

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 數據,顯示如下:

Vue,動態生成,el-checkbox,點擊,無法賦值

綁定的數據居然是 Boolean 類型,怪不得會出現要么全部勾選,要不全部不選

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

假設我在動態生成的時候,就它置為數組格式:

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

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

解決

這是 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, [])})

完美解決~

總結

以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對VeVb武林網的支持。


注:相關教程知識閱讀請移步到JavaScript/Ajax教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 盘山县| 扬中市| 朝阳市| 三台县| 颍上县| 镇坪县| 天津市| 江达县| 大新县| 扶沟县| 平陆县| 隆林| 桂阳县| 于都县| 巴青县| 手游| 宁波市| 浏阳市| 铜川市| 安岳县| 资阳市| 南岸区| 广州市| 静安区| 庄河市| 呼和浩特市| 昔阳县| 广河县| 丹巴县| 高安市| 革吉县| 侯马市| 阳信县| 柳林县| 托里县| 二连浩特市| 奈曼旗| 叶城县| 西吉县| 甘谷县| 壤塘县|