`

锚 点

    博客分类:
  • js
阅读更多
/**
* @author Kira.Sun<sun888lt@163.com>
* @see 用 Javascript 实现锚点(Anchor)间平滑跳转
* @param {}
*            v scroller(el, duration) el : 目标锚点 ID duration : 持续时间,以毫秒为单位,越小越快
* @return {}
* @version 2009-10-10
*/
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
};
34.
}
// 获取滚动条信息
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);
}






jsp
<a href="javascript:scroller('${curPagePlece.englishName}', 800);" >锚</a>




方法二
// 锚点平滑移动
function scroller(tag){
var Duration=500;
if(!tag){
var El = document.getElementsByTagName("body");
El = El.length >= 2 ? El : (El.length == 1 ? El[0] : undefined)
}else{
var El = document.getElementById(tag);
}
if(!El){
return;
}
var elInfo = GetPos(El);
var scroll = GetScroll();
var time = (new Date).getTime();
var timer = setInterval(function (){
var t = (new Date).getTime();
var p = (t - time) / Duration;
if (t >= Duration + time){
clearInterval(timer);
this.timer = null;
}else{
st = ((-Math.cos(p*Math.PI)/2) + 0.5) * (elInfo.y-scroll.t) + scroll.t;
sl = ((-Math.cos(p*Math.PI)/2) + 0.5) * (elInfo.x-scroll.l) + scroll.l;
window.scrollTo(sl, st);
}
}, 13);
//

}

// 转换为数字
function Intval(a){
var v = parseInt(a);
return isNaN(v) ? 0 : v;
}
// 获取元素信息
function GetPos(e){
var offsetLeft = 0;
var offsetTop  = 0;
//offsetWidth、offsetHeight         IE工作区宽和高, IE会加上滚动条的宽度
  //clientWidth、clientHeight         IE可见区宽和高
  //scrollWidth、scrollHeight         IE水平滚动板宽度和垂直滚动板高度
var width = Intval(e.style.width);
var height = Intval(e.style.height);
var offsetWidth = e.offsetWidth;
var offsetHeight = e.offsetHeight;
while (e.offsetParent){
offsetLeft += e.offsetLeft + (e.currentStyle?Intval(e.currentStyle.borderLeftWidth):0);
offsetTop += e.offsetTop  + (e.currentStyle?Intval(e.currentStyle.borderTopWidth):0);
e = e.offsetParent;
}
offsetLeft += e.offsetLeft + (e.currentStyle?Intval(e.currentStyle.borderLeftWidth):0);
offsetTop += e.offsetTop + (e.currentStyle?Intval(e.currentStyle.borderTopWidth):0);
return {
x: offsetLeft,
y: offsetTop,
w: width,
h: height,
wb: offsetWidth,
hb: offsetHeight
};
}

//获取滚动条信息
function GetScroll(){
var scrollTop, scrollLeft, scrollWidth, scrollHeight;
if(document.documentElement && document.documentElement.scrollTop){
scrollTop = document.documentElement.scrollTop;
scrollLeft = document.documentElement.scrollLeft;
scrollWidth = document.documentElement.scrollWidth;
scrollHeight = document.documentElement.scrollHeight;
}else if(document.body){
scrollTop = document.body.scrollTop;
scrollLeft = document.body.scrollLeft;
scrollWidth = document.body.scrollWidth;
scrollHeight = document.body.scrollHeight;
}
return {
t: scrollTop,
l: scrollLeft,
w: scrollWidth,
h: scrollHeight
};
}
分享到:
评论

相关推荐

    考虑锚土相互作用的火箭锚安装分析

    火箭锚的安装分析包括以下几个关键知识点: 1. 火箭锚的定义和优势:火箭锚是一种深水贯入锚,其结构形态类似火箭而得名。它的优势在于造价经济、拖运安装便捷、成本与水深关系不大,适用于深水及超深水域。 2. ...

    z-blog锚文本插件

    在使用"z-blog锚文本插件"时,用户需要注意以下几点: 1. **合理设置锚文本**: 锚文本应与链接页面的内容紧密相关,避免过度优化或使用不相关的关键词,以免被搜索引擎视为垃圾链接,影响网站的整体排名。 2. **...

    深部大断面交岔点加密锚索和对拉锚杆(索)支护技术

    通过分析交岔点巷道的受力及其破坏形式,探索采用了加密锚索和对拉锚杆(索)支护技术,提高了交岔点巷道的支护强度和围岩整体性,改善了牛鼻子的结构,保证了牛鼻子的减跨和对顶板的支撑作用,有效地控制了交岔点巷道的...

    连墙点作法(锚固式)

    锚固式连墙点是其中的一种常见形式,它通过将脚手架与建筑物结构牢固连接,防止因风荷载、施工荷载或其他外力导致的脚手架失稳。下面我们将深入探讨锚固式连墙点的设计原理、施工步骤及注意事项。 一、设计原理 锚...

    锚杆锚索锚固力计算方法.docx

    下面是锚杆锚索锚固力的计算方法和相关知识点: 一、锚杆锚固力计算方法 锚杆锚固力计算方法有多种,但最常见的是使用拉力器上仪表读数和公式计算的方法。该方法将锚杆的拉力器上仪表读数转换为锚固力,然后计算出...

    参考资料-【行为锚定评分法考核工具】行为锚定量表法绩效评价方法.zip

    下面将详细阐述这种评估方法的知识点。 一、行为锚定评分法的基本概念 行为锚定评分法是一种结构化的绩效评估方法,通过将具体的行为实例(行为锚)与特定的评分等级相联系,帮助评估者根据员工的实际工作表现进行...

    井点降水护坡喷锚剖面图

    在建筑工程领域,井点降水护坡喷锚剖面图是一种重要的设计图纸,它涉及到地基处理、土体稳定性以及地下水控制等多个关键环节。这个标题暗示了我们正在讨论一个与地下工程施工相关的技术方案,特别是针对边坡稳定和...

    锚记测试eclipse源代码

    标题“锚记测试eclipse源代码”涉及到的是一个与编程相关的主题,主要集中在Eclipse集成开发环境(IDE)上进行的锚记测试。Eclipse是一个开源的、跨平台的开发工具,广泛用于Java、C++、Python等语言的开发。这里的...

    巷道交岔点锚索U钢梁联合支护的应用研究

    基于分析巷道交岔点围岩变形破坏机理,对巷道交岔点支护方案进行了比较分析,提出将锚索U钢梁联合支护应用于巷道交岔点,并对巷道交岔点进行了支护设计。方案实施后,利用十字观测法,对巷道围岩变形进行了观测,顶底板...

    矿用运输超长锚索平板车的设计与研究

    他们设计了U形槽结构,由5处固定点和10根钢筋挡杆组成,每处固定点设置一对相隔一定距离的钢板或钢筋。这些固定装置可以利用锚索的韧性,将其安全地放置在U形槽内,既保证了锚索的稳定运输,又避免了运输过程中的...

    锚杆锚索联合支护机理及应用

    锚杆的作用机理主要包括以下几点: 1. 挤密效应:锚杆施加预应力后,会对周围岩土体施加径向力,使周围岩土体被挤密,提高其密实度和稳定性。 2. 提高承载力:通过锚杆的锚固作用,可将锚固区的荷载传递到深部稳定...

    施工常用图库-连墙点作法(锚固式).zip

    《施工常用图库-连墙点作法(锚固式)》是一份针对建筑工程领域的专业资料,主要包含了一个名为“连墙点作法(锚固式).DWG”的文件。DWG是AutoCAD设计软件的图形文件格式,通常用于绘制、编辑和分享二维和三维设计...

    无线传感器网络移动锚节点定位

    2. 减少定位误差:移动锚节点可以从多个方向和时刻观测目标节点,减少单点定位的不确定性,提高定位精度。 3. 动态适应性:移动锚节点可以根据网络状况动态调整路径,优化定位服务。 三、移动锚节点定位策略 1. ...

    管道封堵机器人锚定装置设计与分析.pdf

    根据提供的文件内容,我们可以从中提取以下知识点...以上知识点涵盖了文档中提到的关于管道封堵机器人锚定装置设计与分析的多个方面,对于从事油气管道抢修作业的工程师和技术人员来说,这些信息将是非常有价值的参考。

    参考资料-【行为锚定评分法考核工具】月度员工行为锚定考核表.zip

    在使用《行为锚定评分法考核工具》进行月度员工考核时,管理者需要注意以下几点: 1. **公平公正**:确保所有员工都按照同一套标准进行评价,避免个人偏见影响结果。 2. **持续观察**:考核不应只依赖一次性的事件...

    预应力锚索的应用

    该软件基于真实的密度来计算网格点质量,而非静态解决方案中常用的虚拟质量,从而更准确地解决土壤-结构交互作用问题。此外,FLAC3D还能与结构元件模型耦合,这意味着可以分析由于地面震动引起的土壤-结构相互作用。...

Global site tag (gtag.js) - Google Analytics