Vue自定義多選組件使用詳解
本文實例為大家分享了Vue自定義多選組件使用的具體代碼,供大家參考,具體內(nèi)容如下
子組件(選項卡)
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: '選項1' }, { value: 1, name: '選項2' }, { value: 2, name: '選項3' }, { value: 3, name: '選項4' }, { value: 4, name: '選項5' }, { value: 5, name: '選項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>
效果圖
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持好吧啦網(wǎng)。
相關(guān)文章:
1. 以PHP代碼為實例詳解RabbitMQ消息隊列中間件的6種模式2. Python 如何將integer轉(zhuǎn)化為羅馬數(shù)(3999以內(nèi))3. python web框架的總結(jié)4. 詳解Python模塊化編程與裝飾器5. Python通過format函數(shù)格式化顯示值6. html小技巧之td,div標(biāo)簽里內(nèi)容不換行7. python裝飾器三種裝飾模式的簡單分析8. Python如何進行時間處理9. Python實現(xiàn)迪杰斯特拉算法過程解析10. python使用ctypes庫調(diào)用DLL動態(tài)鏈接庫
