爱易网
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 浏览次数:20238 次
以下是程序代码
<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实现链接文字飘浮渐变提示特效代码
免责声明:
本文仅代表作者个人观点,与爱易网无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
相关资料
更多>
组建铁塔公司倒逼运营商改革 或加速4G网建设
盛大游戏走向衰落的根源:免费游戏模式惹的祸
HTC与苹果三星距离扩展 C2B形式成新武器
传搜狗估值12亿美元 与360谈判进入白热化
诺基亚仍是第二大手机商:功用机有利可图
马云寄厚望于物流 “菜鸟”行情暂难持续
Skype周年:与微软联姻到底有没有未来?
从百度世界大会看大数据
谁说黑莓没救?他们在悄悄地深耕企业级市场,在这个领域,苹果三星算什么,他们远远不是黑莓的对手
推荐阅读
更多>
中国移动承诺再降4G资费 网络漫游至50个国家
支付宝曝平安破绽:转账信息被谷歌抓取
阿里巴巴450亿勾画“现代服务业”藏宝图
三星起诉LG在冰箱广告中玷污其企业笼统
传谷歌开发者大会发布Android 4.3 并非5.0版本
中移动推动感地带3G网聊卡 火拼微信沃卡
盘点改变社会的15种科技:谷歌眼镜将使我们成为半机械人
虚拟运营商前路迷茫 业界建议发力车联网
总部大楼已换微软Logo:回忆诺基亚的兴衰史
HTC以品牌营销突围 专家建议改变经营思路
2013年至今中国互联网行业十大并购案汇总
同为70前后人,马云为什么总是像外星人那么瘦
欧洲6万人起诉Facebook隐私侵权
前苹果顾问批判iPhone命名:不应加S
小米2S试水高端化 纯“性价比”玩法已成过去式
联发科享用价钱战 专利难以摆脱高通
苹果音乐效劳新战略:与唱片商停止流媒体协作
谷歌董事长成花花公子:情史足以媲美涂鸦
亚马逊推特价闪购纪念入华十周年 总裁一职仍空缺
迅雷欲3300万美元收购金山快盘 预计9月完成