<!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)
}
}
})
