vue实现tab栏点击高亮效果

时间:2021-05-26

本文实例为大家分享了tab栏实现点击高亮,供大家参考,具体内容如下

之前面试的时候被问到过如何使用vue实现tab栏切换高亮,今天自己写demo顺便记录一下

vue官方文档里有一个基础知识点叫做对象语法

<div class="static" v-bind:class="{ active: isActive, 'text-danger': hasError }"></div>//data如下data: { isActive: true, hasError: false}//渲染结果为<div class="static active"></div>

个人觉得类似三元表达式,如果值为true则给该元素添加上指定的class

实际代码如下

<template> <div> <!-- v-for循环渲染arr --> <!-- 把当前点击的name通过selected传给data里的active --> <!-- 判断如果active的值与当前点击的name相同 则给当前点击的div加上active样式 --> <div id="box" v-for="(item,index) in arr" :key="index" @click = selected(item.name) :class="{active:active == item.name}" > {{item.name}} </div> </div></template><script>export default { name: "index", data() { return { arr: [ { name: "娃哈哈" }, { name: "椰子汁" }, { name: "柠檬茶" }, { name: "可乐" }, { name: "雪碧" } ], active: "娃哈哈" }; }, methods: { selected(name){ this.active = name console.log(name) } }};</script><style>.active { background-color: orange; color: white;}#box { width: 100px; height: 100px; margin: 10px; float: left; border: 1px solid #000;}</style>

我是前端萌新一枚,刚接触前端没多久,vue接触时间就更短了,每天进步一点点!

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。

声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。

相关文章