爱易网
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 浏览次数:20163 次
以下是程序代码
<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实现链接文字飘浮渐变提示特效代码
免责声明:
本文仅代表作者个人观点,与爱易网无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
相关资料
更多>
孙正义入股阿里往事还原:阿里巴巴并非软银首选
特斯拉将获上海免费牌照 充电桩面临双重标准
途牛开盘价9美元 与发行价持平
阿朗力避步北电后尘 急切停止自我革新
支付宝全面封杀比特币:充值码淘宝店或遭封禁
酷派首抓4G时机大丰收,未来份额必降无疑
神州电脑中止IPO面前:再被质疑财务造假
传360周鸿祎曾试图阻止百度收购91无线
任正非:华为决不上市 上市公司股东贪婪而短视
推荐阅读
更多>
传陌陌或12月赴美IPO 估值约30亿美元
NoomWeight减肥
传360周鸿祎曾试图阻止百度收购91无线
快播灭了,还有西瓜:视频网站的灰色江湖还在
京东封杀财付通:终极目标是电商生态圈
170号码扎堆上市:手机话费私人定制时代到来?
神州泰岳雪上加霜:副总违规买卖遭罚
美国政府关门可能影响去哪儿等公司IPO
微软不会被颠覆
网易微博将正式关闭 用户迁至轻博客LOFTER
英特尔IDF峰会启示:释放移动互联的信号
巨人网络回应央视 否认应用黑客停止诈骗
CSS控制字符长度和显示长度
看,网络文学今日之繁盛;忆,纯真去哪了?
谷歌董事长成花花公子:情史足以媲美涂鸦
聚美优品获基石投资1.5亿美金,IPO吃下定心丸
小微型IDC云化趋势加剧 云计算未来或现终极模式
传三星为赢得新兴市场:推廉价版Note3
黑莓高管:黑莓能作为家“小众公司”活下来
众贷网满月开张 网络金融监管再受质疑