中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

如何在Vue中動態生成el-checkbox

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

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

定義的 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, [])
})

為什么要使用Vue

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

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

向AI問一下細節

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

AI

恭城| 沾化县| 龙口市| 彰化县| 天峻县| 环江| 浠水县| 五常市| 武乡县| 巴彦淖尔市| 长子县| 康马县| 永修县| 华亭县| 五原县| 广东省| 江华| 龙井市| 齐齐哈尔市| 拜城县| 芜湖市| 汤阴县| 罗江县| 弥渡县| 扶风县| 大港区| 平陆县| 外汇| 洛浦县| 乌鲁木齐县| 托克逊县| 瓮安县| 梁平县| 溆浦县| 淮安市| 麻阳| 长沙县| 长春市| 大关县| 包头市| 德格县|