原理其实很简单,当currentIndex为0时,数组下标0的元素的active为true,其余的为false,所以为true的元素class会生效。
<body>
<div id="app">
<ul>
<li @click="liClick(index)"
:class="{active:currentIndex==index}"
v-for="(item,index) in list">{{item}}</li>
</ul>
</div>
<script src="./js/vue.js"></script>
<script>
new Vue({
el: "#app",
data: {
list: ["西游记", "红楼梦", "三国演义", "水浒传"],
currentIndex: 0
},
methods: {
liClick(index) {
this.currentIndex=index
}
}
})
</script>
<style>
.active {
color: red;
}
</style>
</body>
输出结果:

该博客介绍了一个使用Vue.js实现的简单列表应用。通过`v-for`指令遍历列表项,并结合`v-bind:class`指令动态设置元素的活跃状态。当用户点击列表项时,`liClick`方法更新`currentIndex`,使得被点击项的`active`类激活,改变文字颜色。这展示了Vue.js的响应式数据绑定和事件处理能力。

626

被折叠的 条评论
为什么被折叠?



