做了一个动感十足的TAB不敢独占,写出来大家共享,大家可以到宝宝孕历首页看看效果。
其实现是通过js控制div的scrollLeft属性来实现的,tab分成两个部分tab头部分和tab体部分,tab体是一个很宽的层,此div的overflow被设置成hidden,在鼠标挪动到不同的tab标签上时,逐渐修改tab体的scrollLeft属性。
实现的js代码如下:
/* scroll */
var Scroller = Class.create();
Scroller.prototype = {
initialize: function (options){
this .commandsWrapId = options.commandsWrapId;
this .scrollWrapId = options.scrollWrapId;
this .sectionWidth = options.sectionWidth;
this .step = options.step;
},
scrollTo : function (ev){
if ( ! ev)ev = window.event;
var otriger = getSrcElement(ev);
while (otriger && otriger.tagName != ' LI ' ){
otriger = otriger.parentNode;
}
Scroller.runningInstance = otriger.scroller;
var instance = otriger.scroller;
for ( var i = 0 ;i instance.triggers[i].className = ' command unselected ' ;
}
otriger.className = ' command selected ' ;
var index = otriger.scrollIndex;
if (instance.interval)window.clearInterval(instance.interval);
instance.targetLeft = index * instance.sectionWidth;
// 计算一个step,要求在500ms内转到指定位置
instance.step = Math.abs((instance.targetLeft - instance.wrap.scrollLeft) / 25);
instance.interval = window.setInterval(instance.scrollByStep, 10 );
},
scrollByStep : function (){
var i = Scroller.runningInstance;
var current = parseInt(i.wrap.scrollLeft);
if (current > i.targetLeft){
if (current - i.targetLeft else i.wrap.scrollLeft = i.wrap.scrollLeft - i.step ;
} else if (current if (i.targetLeft - current else i.wrap.scrollLeft = i.wrap.scrollLeft + i.step;
} else {
if (i.interval){
window.clearInterval(i.interval);
}
}
},
bindEvent : function (scroller){
scroller.wrap = $id(scroller.scrollWrapId);
var ocommands = $id(scroller.commandsWrapId);
var olis = $tagsC( ' LI ' , ' command ' ,ocommands);
scroller.triggers = olis;
if (olis){
for ( var i = 0 ;i olis[i].scrollIndex = i;
olis[i].scroller = scroller;
addEvent(olis[i], ' mouseover ' ,scroller.scrollTo);
}
}
}
};
需要在页面上调用的css和js代码如下:
Code
<script> <br />addLoadEvent(function(){ <br />var scroller = new Scroller({commandsWrapId:'divScrollCommands',scrollWrapId:'divScrollWrap',sectionWidth:600,step:10}); <br />scroller.bindEvent(scroller);}); <br /></script>

公众号网页更新缓存,这玩意儿,说简单也简单,说复杂也够你喝一壶的。你辛辛苦苦更新了公众号文章,结果用户打开还是老版本,这滋味,谁受得了?这篇文章,咱就来扒一扒这背后的弯弯绕绕,以及如何优雅地解决这个问题。读完之后,你就能轻松应对各种缓存难题,让你的用户始终体验到最新鲜的内容。先说点基础的。网页缓存,说白了就是浏览器或者服务器为了提高访问速度,把一些静态资源(比如图片、CSS、JS)或者页面内容存储起来。下次访问时,直接从缓存里取,不用再重新下载,速度自然快。但这玩意儿,也是个双刃剑。新版本上线,

本文讨论了使用HTML5表单验证属性,例如必需的,图案,最小,最大和长度限制,以直接在浏览器中验证用户输入。

本文展示了使用CSS为网页中添加有效的PNG边框。 它认为,与JavaScript或库相比,CSS提供了出色的性能,详细介绍了如何调整边界宽度,样式和颜色以获得微妙或突出的效果

本文讨论了html&lt; datalist&gt;元素,通过提供自动完整建议,改善用户体验并减少错误来增强表格。Character计数:159

本文讨论了HTML&lt; meter&gt;元素,用于在一个范围内显示标量或分数值及其在Web开发中的常见应用。它区分了&lt; meter&gt;从&lt; progress&gt;和前

本文解释了HTML5&lt; time&gt;语义日期/时间表示的元素。 它强调了DateTime属性对机器可读性(ISO 8601格式)的重要性,并在人类可读文本旁边,增强Accessibilit

本文讨论了HTML&lt; Progress&gt;元素,其目的,样式和与&lt; meter&gt;元素。主要重点是使用&lt; progress&gt;为了完成任务和LT;仪表&gt;对于stati


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

适用于 Eclipse 的 SAP NetWeaver 服务器适配器
将Eclipse与SAP NetWeaver应用服务器集成。

螳螂BT
Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

Dreamweaver CS6
视觉化网页开发工具

SublimeText3 Mac版
神级代码编辑软件(SublimeText3)