js各种宽高意义总结

1、window的各种宽高   outerWidth、innerWidth、outerHeight、innerHeight

  1. outerHeight 获取浏览器窗口外部的高度(单位:像素)。表示整个浏览器窗口的高度,包括侧边栏(如果存在)、窗口镶边(window chrome)和调整窗口大小的边框(window resizing borders/handles)
  2. innerHeight 浏览器视口的高度(单位:像素),如果存在水平滚动条则包括它
  3. outerWidth 获取浏览器窗口外部的宽度(单位:像素)。表示整个浏览器窗口的宽度,包括侧边栏(如果存在)、窗口镶边(window chrome)和调整窗口大小的边框(window resizing borders/handles)
  4. innerWidth 浏览器视口的宽度(单位:像素),如果存在垂直滚动条则包括它

 ------以上四个属性仅适用于 IE9+,对于老IE 则需注意两点:

  • IE8及以下不支持 outerWidth 和 outerHeight,且没有提供替代的属性
  • 针对 innerWidth 和 innerHeight,可以用过 document.documentElement.clientWidth/Height (标准模式) 和 document.body.clientWidth/Height (混杂模式) 替代

 ------以下两组属性,声明了窗口的左上角在屏幕上的 x 坐标 和 y 坐标,都不存在兼容性问题

  • screenLeft /  screenTop  适用于 IE、Safari 和 Opera
  • screenX / screenY          适用于 Firefox 和 Safari

2、window.screen 对象表示一个屏幕,包含用户屏幕的信息

  screen对象共包含6个宽高属性 width、height、availWidth、availHeight、availTop、availLeft

  1. width      返回显示器屏幕的宽度(单位:像素)
  2. height     返回显示器屏幕的高度(单位:像素)
  3. availWidth   返回显示屏幕的可用宽度,除 windows 任务栏之外(单位:像素)
  4. availHeight  返回显示屏幕的可用高度,除 windows 任务栏之外(单位:像素)

3、document 相关的宽高

  1.  clientWidth  属性表示元素的内部宽度(单位:像素)。包括内边距,但不包括垂直滚动条(如果有),边框和外边距可以通过 css width + css padding - 垂直滚动条宽度(如果有)来计算
  2.  clientHeight 属性是只读的,对于没有定义css或者内联布局盒子的元素为0,否则,它是元素内部的高度(单位:像素)。包括内边距,但不包括水平滚动条(如果有),边框和外边距
  3.  clientTop  一个元素顶部边框的宽度(单位:像素),不包括顶部外边距或内边距
  4.  clinetLeft 一个元素左边框的宽度(单位:像素),不包括左内边距和左外边距
  5.  offsetWidth   返回一个元素的布局宽度。包括 元素的边框(border)+ 水平线上的内边距(padding)+ 垂直方向滚动条宽度(scrollbar)+ css 设置的宽度(width)
  6.  offsetHeight  返回一个元素的像素高度。包括 元素的边框(border)+ 垂直线上的内边距(padding)+ 水平方向滚动条高度(scrollbar)+ css 设置的高度(height),不包括 :before, :after 等伪元素的宽高
  7.  offsetTop  返回当前元素相对于其 offsetParent 元素的顶部的距离------> (当前元素的祖先元素没有定位,offsetParent 最终是body ------当前元素的祖先元素定位了,offsetParent 取最近的那个祖先元素)
  8.  offsetLeft  返回当前元素左上角相对于其 offsetParent 元素的左边界偏移的距离
  9. scrollWidth 返回元素的内容区域宽度 或 元素的本身的宽度中 更大的那个值。若元素的宽度大于其内容区域(如:存在滚动条时),scrollWidth 要大于 clientWidth
  10.  scrollHeight 等于该元素在不使用滚动条的情况下为了适应视口中所用内容所需的最小高度;若没有垂直滚动条,scrollHeight 与 clientHeight 相同
  11.  scrollLeft  可以读取或设置元素滚动条到元素左边的距离------> (如果元素不能滚动(如:没有溢出),那么 scrollLeft 的值是0) (如果给 scrollLeft 设置的值小于 0,那么 scrollLeft 的值将变为0) ( 如果给 scrollLeft 设置的值小于元素内容最大的宽度,那么 scrollLeft 的值将被设为元素的最大宽度)
  12.  scrollTop 可以获取或设置一个元素的内容垂直滚动的像素数------> ( 如果元素没有垂直方向的滚动条,那么 scrollTop 的值是0) (如果 scrollTop 设置的值小于0, 那么 scrollTop的值将变为0) ( 如果设置超出了这个容器可滚动的值,scrollTop 会被设置为最大值)

4、Event 事件对象的坐标

  1. clientX和clientY ----> 相对于浏览器(可视区左上角0,0)的坐标
  2. screenX和screenY ----> 相对于设备屏幕左上角的(0,0)的坐标
  3. offsetX和offsetY ----> 相对于事件源左上角(0,0)的坐标
  4. pageX和pageY 相对于整个网页左上角(0,0)的坐标
  5. X和Y 本是IE属性,相对于用CSS动态定位的最内容包裹元素

原文地址:https://www.cnblogs.com/yxkNotes/p/11977774.html

时间: 2024-12-31 03:11:52

js各种宽高意义总结的相关文章

js各种宽高(1)

在javascript中操作dom节点让其运动的时候,常常会涉及到各种宽高以及位置坐标等概念,如果不能很好地理解这些属性所代表的意义,就不能理解js的运动原理,同时,由于这些属性概念较多,加上浏览器之间 实现方式不同,常常会造成概念混淆,经过研究之后,这里来进行一个总结. 第一部分:DOM对象 1.1只读属性 所谓的只读属性指的是DOM节点的固有属性,该属性只能通过js去获取而不能通过js去设置,而且获取的值是只有数字并不带单位的(px,em等),如下: 1)clientWidth和client

JS元素宽高、可视区域宽高、滚动区域宽高和已滚动的高度

1.文档的高,屏幕的文档区域的高 document.body.clientHeight 2.有效的高,屏幕可视的高 document.documentElement.clientHeight 3.屏幕的总高度 document.documentElement.scrollHeight 4.滚动的高度 document.documentElement.scrollTop js代码 <script>// 获取有效的宽和高,屏幕可视的宽 高 var winX = document.documentE

JS处理图片宽高

JS快速获取图片宽高的方法 快速获取图片的宽高其实是为了预先做好排版样式布局做准备,通过快速获取图片宽高的方法比onload方法要节省很多时间,甚至一分钟以上都有可能,并且这种方法适用主流浏览器包括IE低版本浏览器. 我们一步一步进入这个过程. 一.简陋的获取图片方式 1 2 3 4 5 6 7 8 9 10 11 // 图片地址 后面加时间戳是为了避免缓存 var img_url = 'http://www.qttc.net/static/upload/2013/13643608813441.

js各种宽高的理解

1.window.innerHeight.window.outerHeight  窗口的外层的高度/内层高度 2.window.innerWidth/window.outerWidth  窗口的外层的宽度/内层宽度 3.window.screen包含有关用户屏幕的信息 window.screen.width window.screen.height window.screen.availWidth(可视化的宽度) window.screen.availHeight(可视化的高度) window.

js/jq宽高的理解与运用

document:1. 与client相关的宽高document.body.clientWidthdocument.body.clientHeightdocument.body.clientLeftdocument.body.clientTop 2. 与offset相关的宽高 3. 与scroll相关的宽高 网页滚动到顶部或底部: <!DOCTYPE html> <html lang="zh-cn"> <head> <meta charset=

JS 各种宽高

1.window的各种宽高   outerWidth.innerWidth.outerHeight.innerHeight outerHeight 获取浏览器窗口外部的高度(单位:像素).表示整个浏览器窗口的高度,包括侧边栏(如果存在).窗口镶边(window chrome)和调整窗口大小的边框(window resizing borders/handles) innerHeight 浏览器视口的高度(单位:像素),如果存在水平滚动条则包括它 outerWidth 获取浏览器窗口外部的宽度(单位

js各种宽高(2)

在javascript和jquery中,都有对各种高度的写法,在这里,我们就着重讲一下窗口.文档等高度的理解.(宽度和高度差不多!) jquery的各种高度 首先来说一说$(document)和$(window),如下:   用一句话理解就是:当网页滚动条拉到最低端时,   $(document).height() == $(window).height() + $(window).scrollTop(). 注意,是拉到最低端! 当网页高度不足浏览器窗口时$(document).height()

js 浏览器 宽高 各种

常用: JS 获取浏览器窗口大小 // 获取窗口宽度   if (window.innerWidth)   winWidth = window.innerWidth;   else if ((document.body) && (document.body.clientWidth))   winWidth = document.body.clientWidth;   // 获取窗口高度   if (window.innerHeight)   winHeight = window.inner

js获取宽高

document.body.clientWidth ==> BODY对象宽度 document.body.clientHeight ==> BODY对象高度 document.documentElement.clientWidth ==> 可见区域宽度 document.documentElement.clientHeight ==> 可见区域高度 网页可见区域宽: document.body.clientWidth 网页可见区域高: document.body.clientHei