jQuery实现导航滚动到指定内容效果完整实例【附demo源码下载】
本文实例讲述了jQuery实现导航滚动到指定内容效果。分享给大家供大家参考,具体如下:
做页面制作也有两年了,其中也做过许多页面效果,有简单的,也有复杂的,今天就来分享一个导航滚动到内容的特效。
平时我们做导航滚动到内容都是通过锚点来做,刷的一下就直接跳到内容了,没有一丝的滚动效果,而且url链接最后会有“小尾巴”,今天我就介绍一款jquery做的滚动的特效,既可以设置滚动速度,又可以在url链接上没有“小尾巴”。
html:
<!DOCTYPEHTML>
<htmllang="en-US">
<head>
<metacharset="UTF-8">
<title></title>
<styletype="text/css">
#a{height:800px;background:red;}
#b{height:800px;background:green;}
#c{height:800px;background:black;}
#d{height:800px;background:yellow;}
</style>
</head>
<body>
<divclass="link">
<ahref="javascript:;"onclick="scroll('a')">1111111111</a>
<ahref="javascript:;"onclick="scroll('b')">2222222222</a>
<ahref="javascript:;"onclick="scroll('c')">3333333333</a>
<ahref="javascript:;"onclick="scroll('d')">4444444444</a>
</div>
<divid="a"></div>
<divid="b"></div>
<divid="c"></div>
<divid="d"></div>
</body>
</html>
<scripttype="text/javascript"src="jquery-1.7.2.min.js"></script>
<scripttype="text/javascript"src="jquery.scrollto.js"></script>
<scripttype="text/javascript">
functionscroll(id){
$("#"+id).ScrollTo(1000);
}
</script>
jquery.scrollto.js:
jQuery.getPos=function(e)
{
varl=0;
vart=0;
varw=jQuery.intval(jQuery.css(e,'width'));
varh=jQuery.intval(jQuery.css(e,'height'));
varwb=e.offsetWidth;
varhb=e.offsetHeight;
while(e.offsetParent){
l+=e.offsetLeft+(e.currentStyle?jQuery.intval(e.currentStyle.borderLeftWidth):0);
t+=e.offsetTop+(e.currentStyle?jQuery.intval(e.currentStyle.borderTopWidth):0);
e=e.offsetParent;
}
l+=e.offsetLeft+(e.currentStyle?jQuery.intval(e.currentStyle.borderLeftWidth):0);
t+=e.offsetTop+(e.currentStyle?jQuery.intval(e.currentStyle.borderTopWidth):0);
return{x:l,y:t,w:w,h:h,wb:wb,hb:hb};
};
jQuery.getClient=function(e)
{
if(e){
w=e.clientWidth;
h=e.clientHeight;
}else{
w=(window.innerWidth)?window.innerWidth:(document.documentElement&&document.documentElement.clientWidth)?document.documentElement.clientWidth:document.body.offsetWidth;
h=(window.innerHeight)?window.innerHeight:(document.documentElement&&document.documentElement.clientHeight)?document.documentElement.clientHeight:document.body.offsetHeight;
}
return{w:w,h:h};
};
jQuery.getScroll=function(e)
{
if(e){
t=e.scrollTop;
l=e.scrollLeft;
w=e.scrollWidth;
h=e.scrollHeight;
}else{
if(document.documentElement&&document.documentElement.scrollTop){
t=document.documentElement.scrollTop;
l=document.documentElement.scrollLeft;
w=document.documentElement.scrollWidth;
h=document.documentElement.scrollHeight;
}elseif(document.body){
t=document.body.scrollTop;
l=document.body.scrollLeft;
w=document.body.scrollWidth;
h=document.body.scrollHeight;
}
}
return{t:t,l:l,w:w,h:h};
};
jQuery.intval=function(v)
{
v=parseInt(v);
returnisNaN(v)?0:v;
};
jQuery.fn.ScrollTo=function(s){
o=jQuery.speed(s);
returnthis.each(function(){
newjQuery.fx.ScrollTo(this,o);
});
};
jQuery.fx.ScrollTo=function(e,o)
{
varz=this;
z.o=o;
z.e=e;
z.p=jQuery.getPos(e);
z.s=jQuery.getScroll();
z.clear=function(){clearInterval(z.timer);z.timer=null};
z.t=(newDate).getTime();
z.step=function(){
vart=(newDate).getTime();
varp=(t-z.t)/z.o.duration;
if(t>=z.o.duration+z.t){
z.clear();
setTimeout(function(){z.scroll(z.p.y,z.p.x)},13);
}else{
st=((-Math.cos(p*Math.PI)/2)+0.5)*(z.p.y-z.s.t)+z.s.t;
sl=((-Math.cos(p*Math.PI)/2)+0.5)*(z.p.x-z.s.l)+z.s.l;
z.scroll(st,sl);
}
};
z.scroll=function(t,l){window.scrollTo(l,t)};
z.timer=setInterval(function(){z.step();},13);
};
调用方法:
$(id).ScrollTo(speed); //id是跳转到内容的id;speed是滚动速度,值越大,滚动越慢
完整实例代码点击此处本站下载。
更多关于jQuery相关内容感兴趣的读者可查看本站专题:《jQuery窗口操作技巧总结》、《jQuery拖拽特效与技巧总结》、《jQuery常用插件及用法总结》、《jquery中Ajax用法总结》、《jQuery表格(table)操作技巧汇总》、《jQuery扩展技巧总结》、《jQuery常见经典特效汇总》、《jQuery动画与特效用法总结》及《jquery选择器用法总结》
希望本文所述对大家jQuery程序设计有所帮助。