爱易网
IT新闻
IT新闻
爱易资讯
网站搭建
云虚拟主机教程
云服务器教程
Apache教程
IIS教程
Nginx教程
网站策划
站长文章
推广教程
淘宝客教程
网页设计
HTML教程
XHTML教程
CSS教程
HTML5教程
CSS3教程
JavaSript基础
JQuery教程
Node.js教程
前端技术
Ajax教程
Js特效
Xml教程
平面设计
页面UI设计
photoshop教程
程序开发
AI人工智能
Asp教程
Php教程
Asp.Net教程
Net Core教程
C#教程
Java教程
Jsp教程
开发技术
微信小程序教程
Uniapp开发教程
微信公众号开发
Andriod教程
IOS教程
DOS教程
Python教程
Docker教程
Windows Container教程
数据库
MSSQL教程
MySQL教程
Redis教程
Access教程
Oracle教程
数据库教程
操作系统
Linux教程
Windows教程
MAC教程
Cisco教程
交换机教程
防火墙教程
搜索
爱易网页
JS特效
用 Javascript 实现锚点(Anchor)间平滑跳转
用 Javascript 实现锚点(Anchor)间平滑跳转
日期:2014-05-18 浏览次数:20162 次
以下是程序代码
<html xmlns="http://www.w3.org/1999/xhtml" > <head runat="server"> <title>用 Javascript 实现锚点(Anchor)间平滑跳转</title> <script language="javascript"> // 说明 :用 Javascript 实现锚点(Anchor)间平滑跳转 // 转换为数字 function intval(v) { v = parseInt(v); return isNaN(v) ? 0 : v; } // 获取元素信息 function getPos(e) { var l = 0; var t = 0; var w = intval(e.style.width); var h = intval(e.style.height); var wb = e.offsetWidth; var hb = e.offsetHeight; while (e.offsetParent) { l += e.offsetLeft + (e.currentStyle?intval(e.currentStyle.borderLeftWidth):0); t += e.offsetTop + (e.currentStyle?intval(e.currentStyle.borderTopWidth):0); e = e.offsetParent; } l += e.offsetLeft + (e.currentStyle?intval(e.currentStyle.borderLeftWidth):0); t += e.offsetTop + (e.currentStyle?intval(e.currentStyle.borderTopWidth):0); return {x:l, y:t, w:w, h:h, wb:wb, hb:hb}; } // 获取滚动条信息 function getScroll() { var t, l, w, h; if (document.documentElement && document.documentElement.scrollTop) { t = document.documentElement.scrollTop; l = document.documentElement.scrollLeft; w = document.documentElement.scrollWidth; h = document.documentElement.scrollHeight; } else if (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 }; } // 锚点(Anchor)间平滑跳转 function scroller(el, duration) { if(typeof el != 'object') { el = document.getElementById(el); } if(!el) return; var z = this; z.el = el; z.p = getPos(el); z.s = getScroll(); z.clear = function() { window.clearInterval(z.timer);z.timer=null }; z.t=(new Date).getTime(); z.step = function() { var t = (new Date).getTime(); var p = (t - z.t) / duration; if (t >= duration + z.t) { z.clear(); window.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 = window.setInterval(function(){z.step();},13); } </script> <style type="text/css"> div.test { width:400px; margin:5px auto; border:1px solid #ccc; } div.test strong { font-size:16px; background:#fff; border-bottom:1px solid #aaa; margin:0; display:block; padding:5px 0; text-decoration:underline; color:#059B9A; cursor:pointer; } div.test p { height:400px; background:#f1f1f1; margin:0; } </style> </head> <body> <form id="form1" runat="server"> <div class="test"> <a name="header_1" id="header_1"></a> <strong onclick="javascript:scroller('header_4', 800);">header_1 --> header_4</strong><p></p> </div> <div class="test"> <a name="header_2" id="he
上一篇:狡猾的按钮特效
下一篇:jquery实现链接文字飘浮渐变提示特效代码
免责声明:
本文仅代表作者个人观点,与爱易网无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
相关资料
更多>
QQ空间与微信龟兔赛跑,商业生态链陷入死循环
美剧讲硅谷创业者:远不及现实荒诞?
手游市场乱象丛生 受资本热捧野蛮成长
9158屌丝逆袭 从在线“夜总会”转型KTV
Docker Desktop 4.11 发布:支持虚拟桌面、Mac 权限更改和新扩展
解读苹果收购Beats背后动机:库克在想什么?
墨迹天气:产品创新以攻为守方能对抗巨头
《归来》遭视频网盗播 乐视网状告小米盒子侵权
评论:马云的成功建立在什么基础上很值得怀疑
推荐阅读
更多>
迅雷高管解读财报:收购快盘可快速融入小米
逆转猜想:如果阿里成为雅虎大股东会怎样?
9月1日起免征新能源汽车购置税
虚拟运营商们更像三大运营商的“二道贩子”
电信资费新政:三巨头压力大 短期降价仍有争议
阿里巴巴IPO难掩的四个现实问题:天猫销售额成谜、淘宝拖后腿、营收迅猛其他不行和投资者未必买账
湖南卫视扶持芒果TV杀入媒体:版权独播不分销
传诺基亚5月14日发布会推出Lumia 950
苹果优势逐渐丧失 传即将推出廉价iPhone
HTC曝出特大丑闻:高管诈骗+商业间谍
京东进驻微信一级入口或影响自身战略布局
国美在线叫板京东:李俊涛底气在哪?
传苹果与雅虎协作信息提供 进一步摆脱谷歌
富士康人事故骚动方寸 不惜血本下注电商
首家国有独资P2P平台上线 或预示政策日渐明朗
谁说黑莓没救?他们在悄悄地深耕企业级市场,在这个领域,苹果三星算什么,他们远远不是黑莓的对手
微软觊觎移动互联市场:手机未出渠道先行
国美苏宁线上首度正面PK 京东列席4月电商战
《归来》遭视频网盗播 乐视网状告小米盒子侵权
微信将商场O2O战火烧到了阿里巴巴老家