用Javascript 获取页面元素的位置的代码


Posted in Javascript onSeptember 25, 2009

下面的教程总结了Javascript在网页定位方面的相关知识。

一、网页的绝对大小和相对大小

首先,要明确两个基本概念。

一张网页的全部面积,就是它的绝对大小。通常情况下,网页的绝对大小由内容和CSS样式表决定。

网页的相对大小则是指在浏览器窗口中看到的那部分网页,也就是浏览器窗口的大小,又叫做viewport(视口)。

下图中央的方框就代表浏览器窗口,每次只能显示一部分网页。

用Javascript 获取页面元素的位置的代码

(图一 网页的绝对大小和相对大小)

很显然,如果网页的内容能够在浏览器窗口中全部显示(也就是不出现滚动条),那么网页的绝对大小和相对大小是相等的。

二、获取网页的相对大小

网页上的每个元素,都有clientHeight和clientWidth属性,利用它们就可以得到网页的相对大小。这两个属性代表的大小,是指元素的内容部分再加上padding的大小,但是不包括border和滚动条占用的空间。

用Javascript 获取页面元素的位置的代码

(图二 clientHeight和clientWidth属性)

因此,document元素的clientHeight和clientWidth属性,就代表了网页的相对大小。

function getViewport(){

if (document.compatMode == "BackCompat"){

return {

width: document.body.clientWidth,

height: document.body.clientHeight

}

} else {

return {

width: document.documentElement.clientWidth,

height: document.documentElement.clientHeight

}

}

}

上面的getViewport函数就可以返回浏览器窗口的高和宽。使用的时候,有三个地方需要注意:
1)这个函数必须在页面加载完成后才能运行,否则document对象还没生成,浏览器会报错。
2)大多数情况下,都是document.documentElement.clientWidth返回正确值。但是,在IE6的quirks模式中,document.body.clientWidth返回正确的值,因此函数中加入了对文档模式的判断。
3)clientWidth和clientHeight都是只读属性,不能对它们赋值。

三、获取网页的绝对大小

document对象的scrollHeight和scrollWidth属性就是网页的绝对大小,意思就是滚动条滚过的所有长度和宽度。

仿照getViewport()函数,可以写出getPagearea()函数。

function getPagearea(){

if (document.compatMode == "BackCompat"){

return {

width: document.body.scrollWidth,

height: document.body.scrollHeight

}

} else {

return {

width: document.documentElement.scrollWidth,

height: document.documentElement.scrollHeight

}

}

}

但是,这个函数有一个问题。前面说过,如果网页内容能够在浏览器窗口中全部显示,不出现滚动条,那么网页的绝对大小与相对大小应该相等,即 clientWidth和scrollWidth应该相等。但是实际上,不同浏览器有不同的处理,这两个值未必相等。所以,我们需要取它们之中较大的那个值,因此要对getPagearea()函数进行改写。

function getPagearea(){

if (document.compatMode == "BackCompat"){

return {

width: Math.max(document.body.scrollWidth,

document.body.clientWidth),

height: Math.max(document.body.scrollHeight,

document.body.clientHeight)

}

} else {

return {

width: Math.max(document.documentElement.scrollWidth,

document.documentElement.clientWidth),

height: Math.max(document.documentElement.scrollHeight,

document.documentElement.clientHeight)

}

}

}

四、获取网页元素的绝对位置

由于网页大小有绝对和相对之分,所以网页元素的位置也有绝对和相对之分。网页元素的左上角相对于整张网页左上角的坐标,就是绝对位置;相对于浏览器窗口左上角的坐标,就是相对位置。

Javascript语言中,网页元素的绝对坐标要通过计算才能得到。每个元素都有offsetTop和offsetLeft属性,表示该元素的左上角与父容器(offsetParent对象)左上角的距离。所以,只需要将这两个值进行累加,就可以得到该元素的绝对坐标。

用Javascript 获取页面元素的位置的代码

(图三 offsetTop和offsetLeft属性)

下面两个函数可以用来获取绝对位置的横坐标和纵坐标。

function getElementLeft(element){

var actualLeft = element.offsetLeft;

var current = element.offsetParent;

while (current !== null){

actualLeft += current.offsetLeft;

current = current.offsetParent;

}

return actualLeft;

}

function getElementTop(element){

var actualTop = element.offsetTop;

var current = element.offsetParent;

while (current !== null){

actualTop += current.offsetTop;

current = current.offsetParent;

}

return actualTop;

}

由于在表格和iframe中,offsetParent对象未必等于父容器,所以上面的函数对于表格和iframe中的元素不适用。

五、获取网页元素的相对位置

有了某个元素的绝对位置以后,获得相对位置就很容易了,只要将绝对坐标减去滚动条滚动的距离就可以了。滚动条滚动的垂直距离,是document对象的scrollTop属性;滚动条滚动的水平距离是document对象的scrollLeft属性。

用Javascript 获取页面元素的位置的代码

(图四 scrollTop和scrollLeft属性)

对上一节中的两个函数进行相应的改写:

function getElementViewLeft(element){

var actualLeft = element.offsetLeft;

var current = element.offsetParent;

while (current !== null){

actualLeft += current.offsetLeft;

current = current.offsetParent;

}

if (document.compatMode == "BackCompat"){

var elementScrollLeft=document.body.scrollLeft;

} else {

var elementScrollLeft=document.documentElement.scrollLeft;

}

return actualLeft-elementScrollLeft;

}

function getElementViewTop(element){

var actualTop = element.offsetTop;

var current = element.offsetParent;

while (current !== null){

actualTop += current. offsetTop;

current = current.offsetParent;

}

if (document.compatMode == "BackCompat"){

var elementScrollTop=document.body.scrollTop;

} else {

var elementScrollTop=document.documentElement.scrollTop;

}

return actualTop-elementScrollTop;

}

scrollTop和scrollLeft属性是可以赋值的,并且会立即自动滚动网页到相应位置,因此可以利用它们改变网页元素的相对位置。另外,element.scrollIntoView()方法也有类似作用,可以使网页元素出现在浏览器窗口的左上角。

六、获取元素位置的快速方法

除了上面的函数以外,还有一种快速方法,可以立刻获得网页元素的位置。

那就是使用getBoundingClientRect()方法。它返回一个对象,其中包含了left、right、top、bottom四个属性,分别对应了该元素的左上角和右下角相对于浏览器窗口(viewport)左上角的距离。

所以,网页元素的相对位置就是

var X= this.getBoundingClientRect().left;

var Y =this.getBoundingClientRect().top;

再加上滚动距离,就可以得到绝对位置

var X= this.getBoundingClientRect().left+document.documentElement.scrollLeft;

var Y =this.getBoundingClientRect().top+document.documentElement.scrollTop;

目前,IE、Firefox 3.0+、Opera 9.5+都支持该方法,而Firefox 2.x、Safari、Chrome、Konqueror不支持。

(完)

Javascript 相关文章推荐
Extjs中ComboBoxTree实现的下拉框树效果(自写)
May 28 Javascript
JavaScript中的值类型详细介绍
Dec 29 Javascript
浅析JavaScript 箭头函数 generator Date JSON
May 23 Javascript
jQuery中实现prop()函数控制多选框(全选,反选)
Aug 19 Javascript
Angular表单验证实例详解
Oct 20 Javascript
给easyui的datebox控件添加清空按钮的实现方法
Nov 09 Javascript
基于jQuery实现表格的排序
Dec 02 Javascript
详解vue项目首页加载速度优化
Oct 18 Javascript
AngularJS实现的鼠标拖动画矩形框示例【可兼容IE8】
May 17 Javascript
js console.log打印对象时属性缺失的解决方法
May 23 Javascript
vue 实现LED数字时钟效果(开箱即用)
Dec 08 Javascript
Vue 列表页带参数进详情页的操作(router-link)
Nov 13 Javascript
Javascript 两个窗体之间传值实现代码
Sep 25 #Javascript
jQuery 使用手册(七)
Sep 23 #Javascript
jQuery 使用手册(六)
Sep 23 #Javascript
jQuery 使用手册(五)
Sep 23 #Javascript
jQuery 使用手册(四)
Sep 23 #Javascript
jQuery 使用手册(三)
Sep 23 #Javascript
jQuery 使用手册(二)
Sep 23 #Javascript
You might like
PHP数组实例总结与说明
2011/08/23 PHP
windows下zendframework项目环境搭建(通过命令行配置)
2012/12/06 PHP
php版微信公众平台接口参数调试实现判断用户行为的方法
2016/09/23 PHP
使用PHPExcel导出Excel表
2018/09/08 PHP
JS实现可展开折叠层的鼠标拖曳效果
2015/10/09 Javascript
javascript实现简单的可随机变色网页计算器示例
2016/12/30 Javascript
vue上传图片组件编写代码
2017/07/26 Javascript
微信小程序使用Promise简化回调
2018/02/06 Javascript
vue 右键菜单插件 简单、可扩展、样式自定义的右键菜单
2018/11/29 Javascript
vue.js的vue-cli脚手架中使用百度地图API的实例
2019/01/21 Javascript
解决layui数据表格排序图标被超出的表头挤出去的问题
2019/09/19 Javascript
详细介绍解决vue和jsp结合的方法
2020/02/06 Javascript
JavaScript实现轮播图特效
2020/04/10 Javascript
python先序遍历二叉树问题
2017/11/10 Python
Python动态生成多维数组的方法示例
2018/08/09 Python
python创建属于自己的单词词库 便于背单词
2019/07/30 Python
Python图像处理模块ndimage用法实例分析
2019/09/05 Python
哈工大自然语言处理工具箱之ltp在windows10下的安装使用教程
2020/05/07 Python
pyqt5实现井字棋的示例代码
2020/12/07 Python
2021年值得向Python开发者推荐的VS Code扩展插件
2021/01/25 Python
使用css3做0.5px的细线的示例代码
2018/01/18 HTML / CSS
AmazeUI 网格的实现示例
2020/08/13 HTML / CSS
美国知名的摄影器材销售网站:Adorama
2017/02/01 全球购物
表达自我的市场:Society6
2018/08/01 全球购物
北美主要的汽车零部件零售商:AutoShack.com
2019/02/23 全球购物
大学自我鉴定范文
2013/12/26 职场文书
大学学雷锋活动总结
2014/06/26 职场文书
联谊活动总结
2014/08/28 职场文书
树转促学习心得体会
2014/09/10 职场文书
领导班子奢靡之风查摆问题及整改措施
2014/09/27 职场文书
团党委领导干部党的群众路线教育实践活动个人对照检查材料思想汇
2014/10/05 职场文书
教师政风行风评议心得体会
2014/10/21 职场文书
纪录片信仰观后感
2015/06/08 职场文书
2016年安康杯竞赛活动总结
2016/04/05 职场文书
Nginx实现负载均衡的项目实践
2022/03/18 Servers
《吸血鬼幸存者》新内容发布 追加多个全新模式
2022/04/07 其他游戏