分享好友 教程首页 教程搜索 频道列表

基于swiper的Tab选项卡

2021-06-19 23:303710
+关注30
核心提示:选项卡五花八门,今天又要用到选项卡,首选swiper!一、HTML布局根据swiper官网的...

选项卡五花八门,今天又要用到选项卡,首选swiper!

一、HTML布局

根据swiper官网的要求来class命名滑块。

<div class="box">
<ul class="swiperTab">
<li> <span>Div+CSS</span> </li>
<li> <span>Javascript+JQuery</span> </li>
<li> <span>AngularJS+Vue+NodeJs</span> </li>
</ul>
<div class="swiper-container">
<div class="swiper-wrapper">
<div class="swiper-slide">千寻Div+CSS</div>
<div class="swiper-slide">阿飞Javascript+JQuery</div>
<div class="swiper-slide">无虑AngularJS+Vue+NodeJs</div>
</div>
</div>
</div>


二、CSS样式

随便写写,根据使用场景调整。(PS:推荐一个在线美化工具

*{margin:0;padding:0}
li{list-style:none}
.box{margin:50px auto;width:800px}
.swiperTab{display:flex;width:100%;flex-direction:row;justify-content:center;align-items:center}
.swiperTab li{display:flex;height:48px;border-left:1px solid #dfdfdf;background-color:#ddf8ff;cursor:pointer;flex:1;flex-direction:row;justify-content:center;align-items:center}
.swiperTab li:first-child{border-left:1px solid transparent}
.swiperTab li.active{background-color:#f60;color:#fff}
.swiperTab li:nth-child(1).active{background-color:#9acd32}
.swiperTab li:nth-child(2).active{background-color:green}
.swiperTab li:nth-child(3).active{background-color:pink}
.swiper-slide{-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;padding:20px}
.swiper-slide:nth-child(1){height:200px;background-color:#9acd32}
.swiper-slide:nth-child(2){height:300px;background-color:green}
.swiper-slide:nth-child(3){height:100px;background-color:pink}


三、Js封装

自己封装的选项卡函数swiperTab.js

function tabs(obj,swiperObj,className) {
var tabSwiper = new Swiper(swiperObj, {
effect : 'flip',//切换效果
speed : 500, //滑动速度,单位ms
autoHeight: true, // 高度随内容变化
onSlideChangeStart : function() {
$(obj+"."+className).removeClass(className); 
$(obj).eq(tabSwiper.activeIndex).addClass(className);
}
});
// 模拟点击事件,如果是移入事件,将mousedown 改为 mouseenter
$(obj).on('touchstart mousedown', function(e) {
e.preventDefault();
$(obj+"."+className).removeClass(className);
$(this).addClass(className); 
tabSwiper.slideTo($(this).index());
});
$(obj).click(function(e) {
e.preventDefault();
});
}


四、Js调用

首先引入相关js

<script src="https://cdn.bootcss.com/jquery/3.2.1/jquery.min.js"></script>
<script src="https://cdn.bootcss.com/Swiper/3.4.2/js/swiper.jquery.min.js"></script>
<script src="js/swiperTab.js"></script>
<script>

$(function () {
//swiperTab 是你导航的className,active是你当前状态的className
$('.swiperTab > li').eq(0).addClass('active');
tabs('.swiperTab > li','.swiper-container','active');
});
</script>


教程完

本文标签: #tab #切换 #点击
免责声明:凡注明来源本网的所有作品,均为本网合法拥有版权或有权使用的作品,欢迎转载,注明出处。非本网作品均来自互联网,转载目的在于传递更多信息,并不代表本网赞同其观点和对其真实性负责。
生成海报
您可能在找更多

Sortable.js:功能强大的JavaScript拖拽库,不依赖JS,DESTOON多图拖拽

    JS库介绍Sortable.js一个功能强大的JavaScript 拖拽库!!!用于在网页上创建可拖放和可排序的元素。它提供了简单而强大的 API,使开发人员能够轻松地实现拖放功能,并允许用户通过拖放来重新排序列表、网格和其他元

网络转载 JavaScript教程2024-04-28

jquery拖拽排序,针对后台列表table进行拖拽排序(测试有用)

    现在很多后台列表为了方便均使用拖拽排序的功能,对列表进行随意的排序。话不多说 ,我在网上找了一些demo,经过对比,现在把方便实用的一个demo列出来,基于jqueryUI.js先上html代码,很简单:

网络转载 JavaScript教程2023-03-16

jQuery-ui插件sortable实现自由拖动排序

    自行用代码测试

网络转载 JavaScript教程2023-03-15

解决TAB切换需拉一下才触发Lazyload懒加载方法

    处理方法就是通过给TAB绑定事件,监控TAB的切换时触发Lazyload懒加载。代码如下

小黑 PC端模板制作2022-09-03

关于touchslider.js滑动切换页面的使用

    需用代码测试

网络转载 移动端模板制作2022-03-19

下一篇
我来说两句
抢沙发