溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何在Vue中動態(tài)生成el-checkbox

發(fā)布時間:2021-05-20 17:01:34 來源:億速云 閱讀:1054 作者:Leah 欄目:web開發(fā)

這篇文章將為大家詳細講解有關(guān)如何在Vue中動態(tài)生成el-checkbox,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。

定義的 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ù),顯示如下:

如何在Vue中動態(tài)生成el-checkbox

綁定的數(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 的深入響應式原理,官方說法和解決方法:

Vue 不允許在已經(jīng)創(chuàng)建的實例上動態(tài)添加新的根級響應式屬性 (root-level reactive property)

然而它可以使用 Vue.set(object, key, value) 方法將響應屬性添加到嵌套的對象上

現(xiàn)在明白了,可以使用 Vue.set 方法解決這個深入式響應原理

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

為什么要使用Vue

Vue是一款友好的、多用途且高性能的JavaScript框架,使用vue可以創(chuàng)建可維護性和可測試性更強的代碼庫,Vue允許可以將一個網(wǎng)頁分割成可復用的組件,每個組件都包含屬于自己的HTML、CSS、JavaScript,以用來渲染網(wǎng)頁中相應的地方,所以越來越多的前端開發(fā)者使用vue。

關(guān)于如何在Vue中動態(tài)生成el-checkbox就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節(jié)

免責聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進行舉報,并提供相關(guān)證據(jù),一經(jīng)查實,將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI