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. JS圖片懶加載庫(kù)VueLazyLoad詳解2. Java實(shí)現(xiàn)的迷宮游戲3. django queryset相加和篩選教程4. Java利用TCP協(xié)議實(shí)現(xiàn)客戶端與服務(wù)器通信(附通信源碼)5. idea設(shè)置提示不區(qū)分大小寫的方法6. Java PreparedStatement用法詳解7. 利用ajax+php實(shí)現(xiàn)商品價(jià)格計(jì)算8. 使用AJAX(包含正則表達(dá)式)驗(yàn)證用戶登錄的步驟9. Spring如何集成ibatis項(xiàng)目并實(shí)現(xiàn)dao層基類封裝10. IDEA 2020.1.2 安裝教程附破解教程詳解

網(wǎng)公網(wǎng)安備