亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

如何在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

濮阳县| 惠水县| 茂名市| 蓬莱市| 太保市| 宜宾市| 安塞县| 昌邑市| 拜城县| 岚皋县| 普兰县| 丰宁| 宜宾县| 西青区| 汝阳县| 青浦区| 闵行区| 吉木萨尔县| 海宁市| 房产| 新安县| 镇宁| 绩溪县| 开化县| 沙坪坝区| 庆城县| 通州市| 齐河县| 萨迦县| 上饶市| 上栗县| 江永县| 巫溪县| 武隆县| 饶平县| 德昌县| 兴义市| 宜川县| 怀集县| 阿鲁科尔沁旗| 琼海市|