使用Vue实现jQuery的切换选中效果
程序员文章站
2022-03-28 11:18:03
...
实际项目中,我们会遇到很多类似的需求,一个列表,需要点击其中一条高亮显示。熟悉JQuery的同学说这个太简单了。可以给这个选中的element设置一个active的class。配合Css样式,让active有选中高亮效果。但是谁说一定要用到jQuery呢。
最近在做的项目中,我尝试脱离JQuery,绕过JQuery,我所接触的大部分项目中好像不使用JQuery无法进行开发一样。它确实给开发者提供了太多便利。以至于大部分web网站都依赖它运行着。据w3Techs统计,JQuery的市场份额高达94.9%,是时候脱离JQuery的束缚了。使用Vue.js
更简洁,快速地实现。
选中效果实现的核心实现逻辑是拷贝一份当前状态作为快照。比对列表的快照和当前的唯一索引,如果相同则视为选中。
<div id="app"> <div class="collection"> <a href="#!" class="collection-item" v-for="gameName in gameNames" @click="selected(gameName)" :class="{active: activeName == gameName}">{{gameName}}</a> </div> </div>
new Vue({ el: "#app", data: { gameNames: ['魔兽世界', '暗黑破坏神Ⅲ', '星际争霸Ⅱ', '炉石传说', '风暴英雄', '守望先锋' ], activeName: '' }, methods: { selected: function(gameName) { this.activeName = gameName } } })
<style>
.active { color: #f00;}
</style>
参考:https://jsfiddle.net/xiaoluoboding/z5xusoL9/
http://xlbd.me/vue-js-selected-highlight/
补充:利用item的index进行判断
<div class="btn-group TP_time_btnBox" role="group">
<template v-for="(item,index) in topoTime.data">
<button type="button" class="btn btn-default" @click="switchTab(item,index)" :class="{active3: topoTime.activeIndex == index}">{{item.name}}</button>
</template>
</div>
.active3{
background: #35bcff!important;
color:#fff!important;
border:1px solid transparent!important;
}
"topoTimeTemp":{
"activeIndex":0,
"data":[
{"name":"现网"},
{"name":"2017--12"},
{"name":"2018--12"},
{"name":"2019--12"}
]
}
data:{
topoTime:{}
}
this.$http.get("scripts/e2e_data.json").then(function(res){
this.topoTime = res.data.result.topoTimeTemp;
}).catch(function(res){
console.log(res);
});
switchTab:function(item,index){
if(this.slideBarSwitch.activeIndex != index){
this.slideBarSwitch.activeIndex = index;
};
}
转载于:https://my.oschina.net/u/3288561/blog/889387
上一篇: JavaScript学习笔记(五)
下一篇: JavaScript 学习笔记 五 函数
推荐阅读
-
vue使用vuex实现首页导航切换不同路由的方法
-
使用vue-router与v-if实现tab切换遇到的问题及解决方法
-
Vue使用vue-area-linkage实现地址三级联动效果的示例
-
jQuery animate()实现背景色渐变效果的处理方法【使用jQuery.color.js插件】
-
vue2.0 使用element-ui里的upload组件实现图片预览效果方法
-
使用vue2实现带地区编号和名称的省市县三级联动效果
-
使用jQuery实现的掷色子游戏动画效果
-
如何使用jQuery定时器的原理实现banner图片切换
-
Vue实现内部组件轮播切换效果的示例代码
-
使用vue.js实现联动效果的示例代码