vue列表切换显示隐藏

实现原理:为每个列表项创建一个单独的组件,然后每个组件都可以拥有自己的isActive标志。

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
<div id="app">
<div v-for="item in items">
<toggle-list-item :item="item"></toggle-list-item>
</div>
</div>

<template id="list-item">
<div>
<div>
{{item.text}}
</div>

<button @click="toggle()">show</button>

<div v-show="isActive" class="item-desc">
{{item.desc}}
</div>

</div>
</template>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
#js
Vue.component('toggle-list-item', {
template: '#list-item',
props: ['item'],
methods: {
toggle() {
this.isActive = !this.isActive;
}
},
data() {
return {
isActive: false
}
},
})

new Vue({
el: '#app',
data: {
items: [{
text: 'foo',
desc: 'foo desc'
}, {
text: 'bar',
desc: 'bar desc'
}, {
text: 'baz',
desc: 'baz desc'
}]
}
});

demo-img

推荐文章