<!DOCTYPE html><html lang="en"> <head> <meta charset="UTF-8"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <meta http-equiv="X-UA-Compatible" content="ie=edge"> <title>Document</title> <script src="https://cdn.bootcss.com/vue/2.6.10/vue.js"></script> </head> <body> <div id="app"> <ul> <li v-for="(item,index) in getlist" :key="index"> <span @click="onclick(index)"> {{arr.includes(index) ? '收缩' : '展开'}} </span> <p v-show="arr.includes(index)">我是展开的内容{{index}}</p> </li> </ul> </div> </body></html>
new Vue({
el:"#app",
data() {
return {
getlist:['1','2','3','4'],
arr:[]
}
},
methods: {
onclick(index) {
let isHas = this.arr.findIndex(i => i == index);
isHas > -1 ? this.arr.splice(isHas,1) : this.arr.push(index)
}
}
})
