Vue.component('question', {
template: '#question',
data: function() {
return {
choosen: undefined
}
},
props: ['data'],
methods: {
onClick: function(choosen) {
this.choosen = choosen;
this.$emit('set-question', this.choosen, this.data.id)
}
}
})
new Vue({
el: "#app",
data: {
question: {},
question1: {
id: 'question1',
list: [
{
id: 'lorem',
text: 'Dogs'
},
{
id: 'aperiam',
text: 'Birds'
},
{
id: 'aperiam2',
text: 'Birds2'
},
{
id: 'aperiam3',
text: 'Birds3'
}
],
title: 'Your favorite pet?'
},
question2: {
id: 'question2',
list: [
{
id: 'lorem',
text: 'Dogs'
},
{
id: 'aperiam',
text: 'Birds'
},
{
id: 'aperiam2',
text: 'Birds2'
},
{
id: 'aperiam3',
text: 'Birds3'
}
],
title: 'Your favorite sport?'
}
},
methods: {
setQuestion: function(choosen, id) {
this.question[id] = choosen;
console.log(this.question);
}
}
})
.choosen{
color: red
}
#app{
padding-bottom: 200px;
}
<script src="https://cdnjs.cloudflare.com/ajax/libs/vue/2.3.4/vue.min.js"></script>
<div id="app">
<question :data="question1" @set-question="setQuestion"></question>
<question :data="question2" @set-question="setQuestion"></question>
</div>
<template id="question">
<div>
<h1>{{data.title}}</h1>
<div class="wrapper">
<div
class="box-holder"
v-for="item in data.list"
:class="{ 'choosen': choosen === item.id }"
>
<div class="box" @click="onClick(item.id)">{{ item.text }}</div>
</div>
</div>
</div>
</template>
Hey Mixa、この素晴らしいおかげでコードなしの提案。複数のセクションを分ける方法はありますか?例えば、お気に入りのペットやお気に入りのスポーツは、互いに影響しないようにしますか? –
コンポーネントを使用して例を追加しました – Mixa