- 浏览: 95067 次
- 性别:
- 来自: 深圳
文章分类
最新评论
/**
* @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
};
}
* @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
};
}
发表评论
-
js验证
2013-09-03 17:22 0<SCRIPT type="text/java ... -
JS 数据类型转换
2013-06-27 09:52 827JS 数据类型转换 方法主要有三种 转换函数、强制类型转换 ... -
javascript 滑动条效果
2012-11-15 09:09 721javascript 滑动条效果 -
js实现(可实现局部打印)
2012-02-22 13:53 1109http://www.iteye.com/topic/1114 ... -
js 获取当前时间,以及js中日期转换成字符串判断问题
2012-02-07 11:03 7560<script> function time_ ... -
xheditor
2012-01-13 15:03 2690<%@ page language="java ... -
jsp写入cookie中文出现乱码问题,history.go(-1) 或 history.back() 网页已过期 解决办法
2011-09-15 11:43 1875第一步:写入cookie时先 ... -
倒计时
2011-08-03 15:55 805<!DOCTYPE HTML PUBLIC " ... -
视频 embed基本语法
2011-06-04 15:46 896embed基本语法 embed ... -
// 每行变色
2011-06-04 11:37 840// 每行变色 <script type=" ... -
常用正则表达式
2011-05-17 10:31 775正则表达式用于字符串处理、表单验证等场合,实用高效。现将一些常 ... -
登录自动回车事件
2011-02-16 14:41 1056<script type="text/java ... -
<bgsound>和<embed>标签
2010-12-21 13:40 1520有两种分别用<bgsound>和<embed ... -
全选,反选.多个复选框发送
2010-12-18 11:22 1069//全选 $("#checkAll" ...
相关推荐
火箭锚的安装分析包括以下几个关键知识点: 1. 火箭锚的定义和优势:火箭锚是一种深水贯入锚,其结构形态类似火箭而得名。它的优势在于造价经济、拖运安装便捷、成本与水深关系不大,适用于深水及超深水域。 2. ...
在使用"z-blog锚文本插件"时,用户需要注意以下几点: 1. **合理设置锚文本**: 锚文本应与链接页面的内容紧密相关,避免过度优化或使用不相关的关键词,以免被搜索引擎视为垃圾链接,影响网站的整体排名。 2. **...
通过分析交岔点巷道的受力及其破坏形式,探索采用了加密锚索和对拉锚杆(索)支护技术,提高了交岔点巷道的支护强度和围岩整体性,改善了牛鼻子的结构,保证了牛鼻子的减跨和对顶板的支撑作用,有效地控制了交岔点巷道的...
锚固式连墙点是其中的一种常见形式,它通过将脚手架与建筑物结构牢固连接,防止因风荷载、施工荷载或其他外力导致的脚手架失稳。下面我们将深入探讨锚固式连墙点的设计原理、施工步骤及注意事项。 一、设计原理 锚...
下面是锚杆锚索锚固力的计算方法和相关知识点: 一、锚杆锚固力计算方法 锚杆锚固力计算方法有多种,但最常见的是使用拉力器上仪表读数和公式计算的方法。该方法将锚杆的拉力器上仪表读数转换为锚固力,然后计算出...
下面将详细阐述这种评估方法的知识点。 一、行为锚定评分法的基本概念 行为锚定评分法是一种结构化的绩效评估方法,通过将具体的行为实例(行为锚)与特定的评分等级相联系,帮助评估者根据员工的实际工作表现进行...
在建筑工程领域,井点降水护坡喷锚剖面图是一种重要的设计图纸,它涉及到地基处理、土体稳定性以及地下水控制等多个关键环节。这个标题暗示了我们正在讨论一个与地下工程施工相关的技术方案,特别是针对边坡稳定和...
标题“锚记测试eclipse源代码”涉及到的是一个与编程相关的主题,主要集中在Eclipse集成开发环境(IDE)上进行的锚记测试。Eclipse是一个开源的、跨平台的开发工具,广泛用于Java、C++、Python等语言的开发。这里的...
基于分析巷道交岔点围岩变形破坏机理,对巷道交岔点支护方案进行了比较分析,提出将锚索U钢梁联合支护应用于巷道交岔点,并对巷道交岔点进行了支护设计。方案实施后,利用十字观测法,对巷道围岩变形进行了观测,顶底板...
他们设计了U形槽结构,由5处固定点和10根钢筋挡杆组成,每处固定点设置一对相隔一定距离的钢板或钢筋。这些固定装置可以利用锚索的韧性,将其安全地放置在U形槽内,既保证了锚索的稳定运输,又避免了运输过程中的...
锚杆的作用机理主要包括以下几点: 1. 挤密效应:锚杆施加预应力后,会对周围岩土体施加径向力,使周围岩土体被挤密,提高其密实度和稳定性。 2. 提高承载力:通过锚杆的锚固作用,可将锚固区的荷载传递到深部稳定...
《施工常用图库-连墙点作法(锚固式)》是一份针对建筑工程领域的专业资料,主要包含了一个名为“连墙点作法(锚固式).DWG”的文件。DWG是AutoCAD设计软件的图形文件格式,通常用于绘制、编辑和分享二维和三维设计...
2. 减少定位误差:移动锚节点可以从多个方向和时刻观测目标节点,减少单点定位的不确定性,提高定位精度。 3. 动态适应性:移动锚节点可以根据网络状况动态调整路径,优化定位服务。 三、移动锚节点定位策略 1. ...
根据提供的文件内容,我们可以从中提取以下知识点...以上知识点涵盖了文档中提到的关于管道封堵机器人锚定装置设计与分析的多个方面,对于从事油气管道抢修作业的工程师和技术人员来说,这些信息将是非常有价值的参考。
在使用《行为锚定评分法考核工具》进行月度员工考核时,管理者需要注意以下几点: 1. **公平公正**:确保所有员工都按照同一套标准进行评价,避免个人偏见影响结果。 2. **持续观察**:考核不应只依赖一次性的事件...
该软件基于真实的密度来计算网格点质量,而非静态解决方案中常用的虚拟质量,从而更准确地解决土壤-结构交互作用问题。此外,FLAC3D还能与结构元件模型耦合,这意味着可以分析由于地面震动引起的土壤-结构相互作用。...