说明,本文全部内容都基于各浏览器的标准渲染模式。也就是在HTML文件首部有标签

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<!DOCTYPE html>

1)鼠标点击事件的坐标,相对于可视区域(Client)左上角

var point_y = evt.clientY;

var point_x = evt.clientX;

其中evt为鼠标点击事件。

2)可视区域左上角的坐标,相对于整个页面(Page)左上角

if(window.pageYOffset != 'undefined') {

point.x = window.pageXOffset;

point.y = window.pageYOffset;

}

else if(typeof document.compatMode != 'undefined' && document.compatMode != 'BackCompat') {

point.x = document.documentElement.scrollLeft;

point.y = document.documentElement.scrollTop;

}

else if(typeof document.body != 'undefined') {

point.x = document.body.scrollLeft;

point.y = document.body.scrollTop;

}

 

关于document.compatMode,请参考 关于document.compatMode的一些介绍

3) 某元素的左上角坐标,相对于整个页面(Page)左上角

function elementLeft(e)

{

var offset = e.offsetLeft;

if(e.offsetParent != null) offset += elementLeft(e.offsetParent);

return offset;

}

4) 网页全文高和宽

网页正文全文宽 document.body.scrollWidth 
网页正文全文高 document.body.scrollHeight

其中,IE7/IE8/IE9/Firefox行为一致,指的都是抛除position=absolute的元素且不管页面缩放的全文高度;Chrome行为稍有不同,计算宽度和高度时包含了position=absolute的元素;且当页面缩放时,当全文高度/宽度小于可视区域的高度和宽度时,给出的是可视区域的高度和宽度。

5)屏幕分辨率的高和宽

屏幕分辨率的高 window.screen.height 
屏幕分辨率的宽 window.screen.width

其中,当页面不缩放时,三种浏览器的行为一致,都是获得真实的屏幕分辨率;

当页面缩放时,Chrome返回的值不变,而IE7/IE8/IE9/Firefox的行为一致,返回 屏幕分辨率/缩放比例。

比如,当屏幕分辨率为1920*1200,缩放比例200%时,返回960*600.

6) 网页可视区域的高和宽

网页可见区域宽 document.body.clientWidth 
网页可见区域高 document.body.clientHeight

该高度和宽度扣除了浏览器右侧和底部的滚动条,也扣除了body的margin.

高度 = Min(页面高度,可视高度)宽度 = Max(页面宽度,可视高度)

其中,如果页面底部是某些元素的margin,则此margin不计算在页面高度内;

注意,页面缩放后,高度不变,宽度为(原始宽度/缩放比例)

7) 网页被卷去的高和宽

网页被卷去的宽度 window.pageXOffset; document.documentElement.scrollLeft;

网页被卷去的高度 window.pageYOffset;document.documentElement.scrollTop;

其中,前者三种浏览器都支持,Chrome不支持后者。

8) 某元素ScrollHeight / OffsetHeight / ClientHeight的区别

OffsetHeight为元素的高度,被挡住的部分同样计算在内;其父元素的overflow属性对此值没有影响;自身的overflow高度对此就没有影响。

scrollHeight为元素的高度,被挡住的部分同样计算在内;其父元素的overflow属性对此值没有影响;受自身的overflow影响。

clientHeight为元素的高度,被挡住的部分同样计算在内;其父元素的overflow属性对此值没有影响;受自身的overflow影响。

经过测试,发现在所有情形下scrollHeight与clientHeight的值都相同...有点诡异。

注意,IE系列浏览器的滚动条的宽度和高度是是固定的16px,不受缩放影响;Firefox和Chrome的滚动条在100%的时候是16px,当缩放时,该宽度和高度发生变化,为 (16/缩放比例)px.

9)某元素的OffsetTop

对于position!=absolute的元素,offsettop为其相对于其祖先元素中最近的一个postion=relative或position=absolute的元素的偏移。

对于position=absolute的元素,offsettop为其top属性指定的值,如果该属性为空,则与position!=absolute的时候算法相同;

10)某元素的ScrollTop

注意,scrollTop是指某一元素内部的元素被卷去的高度;而不是该元素本身被卷去的高度;

只有当该元素的overflow=auto或scroll的时候,该数值才有意义;

说明,本文全部内容都基于各浏览器的标准渲染模式。也就是在HTML文件首部有标签

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">

<!DOCTYPE html>

1)鼠标点击事件的坐标,相对于可视区域(Client)左上角

var point_y = evt.clientY;

var point_x = evt.clientX;

其中evt为鼠标点击事件。

2)可视区域左上角的坐标,相对于整个页面(Page)左上角

if(window.pageYOffset != 'undefined') {

point.x = window.pageXOffset;

point.y = window.pageYOffset;

}

else if(typeof document.compatMode != 'undefined' && document.compatMode != 'BackCompat') {

point.x = document.documentElement.scrollLeft;

point.y = document.documentElement.scrollTop;

}

else if(typeof document.body != 'undefined') {

point.x = document.body.scrollLeft;

point.y = document.body.scrollTop;

}

 

关于document.compatMode,请参考 关于document.compatMode的一些介绍

3) 某元素的左上角坐标,相对于整个页面(Page)左上角

function elementLeft(e)

{

var offset = e.offsetLeft;

if(e.offsetParent != null) offset += elementLeft(e.offsetParent);

return offset;

}

4) 网页全文高和宽

网页正文全文宽 document.body.scrollWidth 
网页正文全文高 document.body.scrollHeight

其中,IE7/IE8/IE9/Firefox行为一致,指的都是抛除position=absolute的元素且不管页面缩放的全文高度;Chrome行为稍有不同,计算宽度和高度时包含了position=absolute的元素;且当页面缩放时,当全文高度/宽度小于可视区域的高度和宽度时,给出的是可视区域的高度和宽度。

5)屏幕分辨率的高和宽

屏幕分辨率的高 window.screen.height 
屏幕分辨率的宽 window.screen.width

其中,当页面不缩放时,三种浏览器的行为一致,都是获得真实的屏幕分辨率;

当页面缩放时,Chrome返回的值不变,而IE7/IE8/IE9/Firefox的行为一致,返回 屏幕分辨率/缩放比例。

比如,当屏幕分辨率为1920*1200,缩放比例200%时,返回960*600.

6) 网页可视区域的高和宽

网页可见区域宽 document.body.clientWidth 
网页可见区域高 document.body.clientHeight

该高度和宽度扣除了浏览器右侧和底部的滚动条,也扣除了body的margin.

高度 = Min(页面高度,可视高度)宽度 = Max(页面宽度,可视高度)

其中,如果页面底部是某些元素的margin,则此margin不计算在页面高度内;

注意,页面缩放后,高度不变,宽度为(原始宽度/缩放比例)

7) 网页被卷去的高和宽

网页被卷去的宽度 window.pageXOffset; document.documentElement.scrollLeft;

网页被卷去的高度 window.pageYOffset;document.documentElement.scrollTop;

其中,前者三种浏览器都支持,Chrome不支持后者。

8) 某元素ScrollHeight / OffsetHeight / ClientHeight的区别

OffsetHeight为元素的高度,被挡住的部分同样计算在内;其父元素的overflow属性对此值没有影响;自身的overflow高度对此就没有影响。

scrollHeight为元素的高度,被挡住的部分同样计算在内;其父元素的overflow属性对此值没有影响;受自身的overflow影响。

clientHeight为元素的高度,被挡住的部分同样计算在内;其父元素的overflow属性对此值没有影响;受自身的overflow影响。

经过测试,发现在所有情形下scrollHeight与clientHeight的值都相同...有点诡异。

注意,IE系列浏览器的滚动条的宽度和高度是是固定的16px,不受缩放影响;Firefox和Chrome的滚动条在100%的时候是16px,当缩放时,该宽度和高度发生变化,为 (16/缩放比例)px.

9)某元素的OffsetTop

对于position!=absolute的元素,offsettop为其相对于其祖先元素中最近的一个postion=relative或position=absolute的元素的偏移。

对于position=absolute的元素,offsettop为其top属性指定的值,如果该属性为空,则与position!=absolute的时候算法相同;

10)某元素的ScrollTop

注意,scrollTop是指某一元素内部的元素被卷去的高度;而不是该元素本身被卷去的高度;

只有当该元素的overflow=auto或scroll的时候,该数值才有意义;

Javascript获取页面的各种坐标汇总的更多相关文章

  1. 用JavaScript获取页面上被选中的文字的技巧

    这里介绍的一个小技巧是如何用JavaScript获取页面上被选中的文字的方法.最关键的JavaScript API是: event.selection = window.getSelection(); ...

  2. 用javaScript获取页面元素值

    用JavaScript获取页面元素常见的三种方法:                                                           getElementById() ...

  3. JavaScript获取页面元素的常用方法

    1.通过标签获取元素,返回一个数组 var li = document.getElementsByTagName('li');//标签获取元素 li[0].innerHTML;// 查看获取元素的内容 ...

  4. javascript 获取页面的高度及滚动条的位置的代码

    http://www.jb51.net/article/23331.htm javascript 获取页面的高度及滚动条的位置的代码 作者: 字体:[增加 减小] 类型:转载   javascript ...

  5. 用 Javascript 获取页面大小、窗口大小和滚动条位置

    页面大小.窗口大小和滚动条位置这三个数值在不同的浏览器例如 Firefox 和 IE 中有着不同的实现.即使在同一种浏览器例如 IE 中,不同版本也有不同的实现. 本文给出两个能兼容目前所有浏览器的 ...

  6. 利用JavaScript获取页面文档内容

    JavaScript的document对象包含了页面的实际内容,所以利用document对象可以获取页面内容,例如页面标题.各个表单值. <!DOCTYPE html> <html ...

  7. javascript获取页面文档内容

    <html> <head> <title>JavaScript基础</title> </head> <body> <p&g ...

  8. javascript 获取页面尺寸/位置

    ************************************************************************//ie中如果全部不给定值则会都为零(宽和高在设置一个的 ...

  9. Javascript 获取页面高度(多种浏览器)

    //2015年8月13日11:00:50 网页可见区域宽: document.body.clientWidth网页可见区域高: document.body.clientHeight网页可见区域宽: d ...

随机推荐

  1. Kubernetes StatefulSet

    StatefulSet 简介 在Kubernetes中,Pod的管理对象RC.Deployment.DaemonSet和Job都是面向无状态的服务.但现实中有很多服务是有状态的,特别是一些复杂的中间件 ...

  2. 【神经网络与深度学习】【计算机视觉】Fast R-CNN

    转自:https://zhuanlan.zhihu.com/p/24780395?refer=xiaoleimlnote 首先声明:本文很多内容来自两个博客: RCNN, Fast-RCNN, Fas ...

  3. (转)面试前必知Redis面试题—缓存雪崩+穿透+缓存与数据库双写一致问题

    背景:redis问题在面试过程中经常被问到,对于常见问题一定不能放过. 面试前必知Redis面试题—缓存雪崩+穿透+缓存与数据库双写一致问题 一.缓存雪崩 1.1什么是缓存雪崩? 如果缓存数据设置的过 ...

  4. elasticsearch的数据写入流程及优化

    Elasticsearch 写入流程及优化 一. 集群分片设置:ES一旦创建好索引后,就无法调整分片的设置,而在ES中,一个分片实际上对应一个lucene 索引,而lucene索引的读写会占用很多的系 ...

  5. 没有索引导致的DIRECT PATH READ

    5月20号下午4-5点,某项目组进行数据入库作业,作业人员反映入库速度很慢.在16:30和16:50分别采集了快照,并根据两个快照得到AWR报告. 直接看TOP 5 EVENTS,这是数据库问题诊断的 ...

  6. java笔记--java的语言特性

    java的语言特性 1.简单性:例如:java不再支持多继承,而c++是支持多继承的,多继承比较复杂. c++中有指针,java中屏蔽了指针的概念.所以相对来说比较简单. //注:java语言的底层是 ...

  7. 【C#】上机实验九

    1. 设计一个Windows登陆窗体应用程序,能够实现根据现有表中数据模拟登陆,并设置相关属性,具体界面如下. 可能使用到的类: (1)SqlConnection (2)SqlCommand (3)S ...

  8. ApachShiro 一个系统 两套验证方法-(后台管理员登录、前台App用户登录)同一接口实现、源码分析

    需求: 在公司新的系统里面博主我使用的是ApachShiro 作为安全框架.作为后端的鉴权以及登录.分配权限等操作 管理员的信息都是存储在管理员表 前台App 用户也需要校验用户名和密码进行登录.但是 ...

  9. Bean进行操作的相关工具方法

    Bean进行操作的相关工具方法 /** * <html> * <body> * <P> Copyright 1994 JsonInternational</p ...

  10. Linux虚拟机设置静态ip

    二.设置静态ip dhclient 动态分配ip 修改 ifcfg-ens33网卡配置文件  静态分配ip dhclient -r (释放动态分配的ip地址) vi /etc/sysconfig/ne ...