Vue動態(tài)生成el-checkbox點擊無法賦值的解決方法
前言
最近遇到一個問題,在一個頁面需要動態(tài)渲染頁面內(nèi)的表單,其中包括 checkbox 表單類型,并且使用 Element 組件 UI 時,此時 v-model 綁定的數(shù)據(jù)也是動態(tài)生成的
例如:
定義的 data 的 form 里面是空對象,需要動態(tài)生成里面的 key
export default { data() { return { form: {} } }, }
從后端接口得到 checkList,這個就是動態(tài)生成的表單數(shù)據(jù)
v-for 循環(huán) checkList,得到 key,然后直接 v-model=“form.key”
動態(tài)生成 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>
問題來了
當頁面點擊動態(tài)生成的 CheckBox 方框,會出現(xiàn)全選的情況,查看 vue 數(shù)據(jù),顯示如下:
綁定的數(shù)據(jù)居然是 Boolean 類型,怪不得會出現(xiàn)要么全部勾選,要不全部不選
正常的情況 CheckBox 的綁定數(shù)據(jù)類型是數(shù)組形式
假設(shè)我在動態(tài)生成的時候,就它置為數(shù)組格式:
this.checkList.forEach(item => { let key = item.code this.form[key] = [] })
但發(fā)現(xiàn)還是沒用,會發(fā)現(xiàn)點擊任何 CheckBox 都無法勾選
解決
這是 vue 的深入響應(yīng)式原理,官方說法和解決方法:
Vue 不允許在已經(jīng)創(chuàng)建的實例上動態(tài)添加新的根級響應(yīng)式屬性 (root-level reactive property)
然而它可以使用 Vue.set(object, key, value)
方法將響應(yīng)屬性添加到嵌套的對象上
現(xiàn)在明白了,可以使用 Vue.set
方法解決這個深入式響應(yīng)原理
this.checkList.forEach(item => { let key = item.code this.$set(this.form, key, []) })
完美解決~
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
vue-cli3 項目優(yōu)化之通過 node 自動生成組件模板 generate View、Component
這篇文章主要介紹了vue-cli3 項目優(yōu)化之通過 node 自動生成組件模板 generate View、Component的相關(guān)知識,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2019-04-04解決vue-cli創(chuàng)建項目的loader問題
下面小編就為大家分享一篇解決vue-cli創(chuàng)建項目的loader問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看看吧2018-03-03