Vue自定義多選組件使用詳解
本文實(shí)例為大家分享了Vue自定義多選組件使用的具體代碼,供大家參考,具體內(nèi)容如下
子組件(選項(xiàng)卡)
checkBoxCard.vue
<template> <div class='checkBoxCard'> <div : @click='checked(), updateData()'> {{ name }} </div> </div></template><script>export default { name: 'checkBoxCard', props: { name: String, checkIndex: { type: Number, default: null, }, }, data() { return { radio: 0, check: false, radioName: '', list: [], }; }, methods: { checked() { if (this.radio == 1) { this.check = false; this.radio = 0; } else if (this.radio == 0) { this.check = true; this.radio = 1; } }, updateData() { if (this.radio == 1) { this.radioName = this.name; } else if (this.radio == 0) { this.radioName = ''; } this.$emit('updateSurveyData', this.radioName, this.checkIndex); }, }, mounted() {}, created() {},};</script><style lang='scss' scoped>.checkBoxCard { margin-right: 15px; display: inline-block; margin-top: 10px;}.boxCheck { color: rgba(183, 37, 37, 1); background: bisque;}.box { border: 0.55px solid #eee; padding: 5px 10px; font-size: 3.73333vw; border-radius: 10px;}</style>
父組件
checkBox.vue
<template> <div class='checkBox'> <div class='title'> 選擇 </div> <div class='card'> <CheckBoxCard v-for='item in list' :key='item.value' :name='item.name' :checkIndex='item.value' @updateSurveyData='updateSurveyData' /> </div> </div></template><script>import CheckBoxCard from './checkBoxCard';export default { name: 'checkBox', components: { CheckBoxCard, }, data: function () { return { list: [ { value: 0, name: '選項(xiàng)1' }, { value: 1, name: '選項(xiàng)2' }, { value: 2, name: '選項(xiàng)3' }, { value: 3, name: '選項(xiàng)4' }, { value: 4, name: '選項(xiàng)5' }, { value: 5, name: '選項(xiàng)6' }, { value: 6, name: '其他' }, ], name: '', checkList: [], }; }, methods: { updateSurveyData(question, index) { this.checkList[index] = question; console.log(this.checkList.filter((x) => x != '')); console.log(this.checkList.filter((x) => x != '').join()); }, }, created() {},};</script><style scoped>.checkBox { padding: 5.33333vw 4vw; border-bottom: 0.55px solid #eee; background: white;}.title { text-align: left; color: #323233; font-size: 3.73333vw; padding-bottom: 10px; line-height: 30px;}</style>
效果圖
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. 使用Docker的NFS-Ganesha鏡像搭建nfs服務(wù)器的詳細(xì)過(guò)程2. Django使用HTTP協(xié)議向服務(wù)器傳參方式小結(jié)3. 手機(jī)屏幕尺寸測(cè)試——手機(jī)的實(shí)際顯示頁(yè)面的寬度4. HTML 絕對(duì)路徑與相對(duì)路徑概念詳細(xì)5. Django模板標(biāo)簽中url使用詳解(url跳轉(zhuǎn)到指定頁(yè)面)6. XML輕松學(xué)習(xí)手冊(cè)(一):XML快速入門7. WML語(yǔ)言的基本情況8. 帶你了解CSS基礎(chǔ)知識(shí),樣式9. 推薦一個(gè)好看Table表格的css樣式代碼詳解10. CSS代碼檢查工具stylelint的使用方法詳解
