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程序设计有所帮助。