這篇文章將為大家詳細講解有關(guān)如何在Vue中動態(tài)生成el-checkbox,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關(guān)知識有一定的了解。
創(chuàng)新互聯(lián)為企業(yè)級客戶提高一站式互聯(lián)網(wǎng)+設(shè)計服務(wù),主要包括成都做網(wǎng)站、成都網(wǎng)站建設(shè)、成都APP應(yīng)用開發(fā)、微信小程序定制開發(fā)、宣傳片制作、LOGO設(shè)計等,幫助客戶快速提升營銷能力和企業(yè)形象,創(chuàng)新互聯(lián)各部門都有經(jīng)驗豐富的經(jīng)驗,可以確保每一個作品的質(zhì)量和創(chuàng)作周期,同時每年都有很多新員工加入,為我們帶來大量新的創(chuàng)意。定義的 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, []) })為什么要使用Vue
Vue是一款友好的、多用途且高性能的JavaScript框架,使用vue可以創(chuàng)建可維護性和可測試性更強的代碼庫,Vue允許可以將一個網(wǎng)頁分割成可復(fù)用的組件,每個組件都包含屬于自己的HTML、CSS、JavaScript,以用來渲染網(wǎng)頁中相應(yīng)的地方,所以越來越多的前端開發(fā)者使用vue。
關(guān)于如何在Vue中動態(tài)生成el-checkbox就分享到這里了,希望以上內(nèi)容可以對大家有一定的幫助,可以學(xué)到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
當前標題:如何在Vue中動態(tài)生成el-checkbox-創(chuàng)新互聯(lián)
鏈接分享:http://www.rwnh.cn/article24/igoje.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供關(guān)鍵詞優(yōu)化、ChatGPT、建站公司、App開發(fā)、定制開發(fā)、面包屑導(dǎo)航
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容