很好用的Tab标签切换功能,延迟Tab切换。
一个网页,Tab标签的切换是常见的功能,但我发现很少有前端工程师在做该功能的时候,会为用户多想想,如果你觉得鼠标hover到标签上,然后切换到相应的内容,就那么简单的话,你将是一个不合格的前端工程师啊,其实你不这样做,也无伤大雅,但是作为前端的工程师,我们可以为用户做到更好。想想如果一个网页上,有很多标签,而用户鼠标在不经意间快速的滑动了一下,如果tab标签的切换不经过特殊的处理的话,标签所对应的内容会一同切换,甚至还会想服务器请求内容,增加服务器开销,很显然这一行为不是用户想要的,我们完全可以避免或者减少这种情况发生,通过延迟加切换标签的操作,来提高用户体验,在多标签的网页上,这种尤为重要。下面直接贴源码,大家可以直接使用。
html源码:
<div class="Pannel ">
<div class="tabTitle ">
<ul class="tabs">
<li class="current"><a target="_blank">标签一</a></li>
<li ><a target="_blank">标签二</a></li>
</ul>
<div class="more">
<a target="_blank" href="">更多</a>
</div>
</div>
<div class="tabList">
<div class="linklist f14">
标签一内容
</div>
<div style="display: none;" class="linklist f14">
标签二内容
</div>
</div>
</div>
JS调用方式:
jQuery(".Pannel").Tabs(tabSelector: ".tabs li", conSelector: ".linklist", focusClass: "current"); //参数配置参考你具体的Class
Tab切换源码
jQuery.fn.Tabs = function (options) {
var defaults = {
tabSelector: ".tabs li", // 标签选项卡
conSelector: ".tabcontent", //选项卡内容
focusClass: "c", //标签选中后的样式
moreTrigger: ".tabTitle .more .link", // 扩展 选项卡上有更多的链接情况
events: "mouseover", //事件类型,支持"mouseover", "click"
selected: 0, //默认选中标签项
delay: 0.2 //事件延迟时间
};
var events = ["mouseover", "click"];
var settings = jQuery.extend({}, defaults, options);
var that = this;
var _tabs = jQuery(settings.tabSelector, that);
var _cons = jQuery(settings.conSelector, that);
var _more = jQuery(settings.moreTrigger, that);
var _isDelay = settings.events == events[0] ? !0 : !1;
void function () {
var tab = _tabs.eq(settings.selected);
if (tab && tab.length == 0) {
tab = _tabs.eq(0);
}
tab.addClass(settings.focusClass);
tab.siblings(settings.tabSelector).removeClass(settings.focusClass);
var cons = _cons.eq(settings.selected);
if (cons && cons.length == 0) {
cons = _cons.eq(0);
}
cons.show();
cons.siblings(settings.conSelector).hide();
var more = _more.eq(settings.selected);
if (more && more.length == 0) {
more = _more.eq(0);
}
more.show();
more.siblings().hide();
}();
_tabs.each(function (i, v) {
jQuery(v).on(settings.events, function () {
var _this = this;
delay.apply(this, [settings.delay, function () {
jQuery(_this).addClass(settings.focusClass);
jQuery(_this).siblings(settings.tabSelector).removeClass(settings.focusClass);
jQuery(_cons[i]).show();
jQuery(_cons[i]).siblings(settings.conSelector).hide();
jQuery(_more[i]).show();
jQuery(_more[i]).siblings().hide();
}, _isDelay])
});
});
//接收两个参数 t延迟时间秒为单位,fn要执行的函数,m是否执行延迟取决于事件的类型
var delay = function (t, fn, m) {
if (m) {
var _this = this,
d = setInterval(function () {
fn.apply(_this);
}, t * 1000);
_this.onmouseout = function () {
clearInterval(d);
};
}
else fn.apply(this);
}
}
很好用的Tab标签切换功能,延迟Tab切换。的更多相关文章
- 类似掌盟的Tab页 Android 开源框架ViewPageIndicator 和 ViewPager 仿网易新闻客户端Tab标签 (转)
原博客地址 :http://blog.csdn.net/xiaanming/article/details/10766053 本文转载,记录学习用,如有需要,请到原作者网站查看(上面这个网址) 之前 ...
- Android 开源框架ViewPageIndicator 和 ViewPager 仿网易新闻客户端Tab标签
转载请注明出处:http://blog.csdn.net/xiaanming/article/details/10766053 之前用JakeWharton的开源框架ActionBarSherlock ...
- JS 实现 Tab标签切换功能
Tab标签切换 效果图: HTML部分: <div class="wrap"> <ul id="tag"> < ...
- javascript回车完美实现tab切换功能
javascript通过回车实现tab切换功能,最经有一个项目是给化工厂做的在使用的过程中需要输入大量的数据,使用的都是小键盘区,在以前都是通过excel录入数据的现在, 在网页上需要实现excel ...
- Vue + Element-ui实现后台管理系统(3)---面包屑 + Tag标签切换功能
面包屑 + Tag标签切换功能 有关后台管理系统之前写过两遍博客,看这篇之前最好先看下这两篇博客.另外这里只展示关键部分代码,项目代码放在github上: mall-manage-system 1.V ...
- 多iframe使用tab标签方式添加、删除、切换的处理实例
紧接着上一篇随笔iframe的内容增高或缩减时设置其iframe的高度的处理方案 如果采用iframe来切换显示内容的方式来展现办公Web.那么需要解决几个问题 1.tab标签需要和显示的iframe ...
- jquery切换tab标签例子
之前做了一个简单的小效果,使用jquery方式,让tab标签切换,效果如下 代码其实很简单,首先先把代码分享给大家,代码如下 var shoptoggle = $('.shoptoggle .shop ...
- VIM 实现tab标签页及分屏,切换命令
1,在一个窗口中,VIM 的小tab标签页命令: :tabnew [++opt选项] [+cmd] 文件 建立对指定文件新的tab :tabc 关闭当前的tab ...
- html+css+jQuery+JavaScript实现tab自动切换功能
tab1.html内容 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> & ...
随机推荐
- L1、L2范式及稀疏性约束
L1.L2范式及稀疏性约束 假设需要求解的目标函数为: E(x) = f(x) + r(x) 其中f(x)为损失函数,用来评价模型训练损失,必须是任意的可微凸函数,r(x)为规范化约束因子,用来对模型 ...
- 编写优质无错C程序秘诀!《经验谈》
这里我将陆续给大家载出我在以前学习和编写c代码时遇到的问题和解决方法.学习的心得,有些是经过查询一些曾经参加微软microsoft的开发小组的老程序员的书籍和资料后提供给大家! 首先,当发现错误时,要 ...
- scanf(),fscanf的详解
我们这里只讨论fscanf(或者scanf)的格式,因为这些细节在其他贴里并没有涉及,阅读此文,你可以少走一些弯路.只讲结果,深层原因并不分析. FILE *pFile:float x1; char ...
- 依据 smtp协议的简单golang 的发邮件实现
依据 smtp协议的简单golang 的发邮件实现 协议格式如下 From:sender_user@demo.net To:to_user@demo.net Subject:这是主题 Mime-Ver ...
- BZOJ1612: [Usaco2008 Jan]Cow Contest奶牛的比赛
1612: [Usaco2008 Jan]Cow Contest奶牛的比赛 Time Limit: 5 Sec Memory Limit: 64 MBSubmit: 645 Solved: 433 ...
- 使用 Gradle 实现 TFS 构建自动化
发布于 2014-07-16 作者 陈 忠岳 感谢微软开放技术有限公司(简称"微软开放技术")发布的构建模板,我们现在便可以在 Team Foundation Server(TFS ...
- 汇编学习笔记(14)BIOS对键盘输入的处理
字符的处理 键盘输入的字符一般由int9中断例程从60h端口中读取,并存放在键盘缓冲区中,由int16h例程从键盘缓冲区中读取相应字符,CPU对键盘输入a.shift_a的处理过程如下 1.一开始没有 ...
- hdu 2546 典型01背包
分析:每种菜仅仅可以购买一次,但是低于5元不可消费,求剩余金额的最小值问题..其实也就是最接近5元(>=5)时, 购买还没有买过的蔡中最大值问题,当然还有一些临界情况 1.当余额充足时,可以随意 ...
- ReactiveCocoa Tutorial
ReactiveCocoa Tutorial – The Definitive Introduction: Part 1/2 ReactiveCocoa教程——明确的介绍:第一部分(共两部分) As ...
- openstack 启用spice
Openstack启用spice协议 #控制节点 #安装 ? 1 apt-get install nova-spiceproxy spice-html5 spice-vdagent #配置 nano ...