我正试图绕过vue.js,但我似乎错过了必不可少的东西。
我有几个盒子,我希望它们像手风琴一样(只显示一个;打开另一个盒子关闭前一个盒子)。这是我的代码:
<div id="app">
<div class="block">
<button v-on:click="mytoggle(0,$event)">block one</button>
<div v-if="boxes[0]">
<p>i am box number one</p>
<p>i am box number one</p>
</div>
</div>
<div class="block">
<button v-on:click="mytoggle(1,$event)">block two</button>
<div v-if="boxes[1]">
<p>i am box number two</p>
<p>i am box number two</p>
</div>
</div>
<div class="block">
<button v-on:click="mytoggle(2,$event)">block three</button>
<div v-if="boxes[2]">
<p>i am box number three</p>
<p>i am box number three</p>
</div>
</div>
<pre>{{ $data | json }}</pre>
</div>
和脚本:
var vm = new Vue({
el: '#app',
methods: {
mytoggle: function (n, event) {
event.preventDefault();
for(var i = 0; i < 3; i++) { // close all boxes
this.boxes[i] = false;
}
this.boxes[n] = true; // open the corresponding box
console.log(n);
}
},
data: {
boxes: [false,true,false]
}
});
加载页面时,会显示第二个框(这是正确的,因为boxes数组中的第二个元素为true)。
但是点击按钮不会改变box.array或框的显示。日志告诉我,这样的脚本似乎工作,因为我在单击按钮时记录了正确的值。 所以我想它在绑定中有所作为。 有人能带领我走上正轨吗?
答案 0 :(得分:0)
试试这个:
HTML:
<div id="app">
<div class="block">
<button @click.prevent="mytoggle(0)">block one</button>
<div v-show="boxes[0].show">
<p>i am box number one</p>
<p>i am box number one</p>
</div>
</div>
<div class="block">
<button @click.prevent="mytoggle(1)">block two</button>
<div v-show="boxes[1].show">
<p>i am box number two</p>
<p>i am box number two</p>
</div>
</div>
<div class="block">
<button @click.prevent="mytoggle(2)">block three</button>
<div v-show="boxes[2].show">
<p>i am box number three</p>
<p>i am box number three</p>
</div>
</div>
<hr/>
<pre>{{ boxes | json}}</pre>
</div>
Vue的:
var vm = new Vue({
el: '#app',
data: {
boxes: [{show:false},{show:true},{show:false}]
},
methods: {
mytoggle: function (n) {
for(var i = 0; i < 3; i++) { // close all boxes
vm.boxes[i].show = false;
}
vm.boxes[n].show = true; // open the corresponding box
}
}
});
小提琴: https://jsfiddle.net/crabbly/9a6bua6x/
编辑:
您也可以使用Vue mytoggle
更改$set
方法以更改数组值:
mytoggle: function (n, event) {
event.preventDefault();
for(var i = 0; i < 3; i++) { // close all boxes
this.boxes.$set(i, false);
}
this.boxes.$set(n, true); // open the corresponding box
console.log(n);
}
答案 1 :(得分:0)
您应该使用$set
方法,而不是直接更改。 [ref]
此外,您可以使用更简单的解决方法:
new Vue({
el: '#app',
data: {
selected: 1
},
methods: {
select (index) {
this.selected = index
},
isSelected (index) {
return this.selected === index
}
}
})
<script src="https://cdnjs.cloudflare.com/ajax/libs/vue/1.0.24/vue.min.js"></script>
<div id="app">
<div class="block">
<button @click="select(0)">block one</button>
<div v-show="isSelected(0)">
<p>i am box number one</p>
<p>i am box number one</p>
</div>
</div>
<div class="block">
<button @click="select(1)">block two</button>
<div v-show="isSelected(1)">
<p>i am box number two</p>
<p>i am box number two</p>
</div>
</div>
<div class="block">
<button @click="select(2)">block three</button>
<div v-show="isSelected(2)">
<p>i am box number three</p>
<p>i am box number three</p>
</div>
</div>
</div>