提示:document.documentElement 和 document.getElementsByTagName('html')[0] 是一样的;

1、视口大小(不包括滚动条,视口字面理解当然是不包括滚动条),

document.documentElement.clientWidth

document.documentElement.clientHeight

即使给 html 元素显示设置了宽高,返回的值也仍然是视口的尺寸,这是非常特殊的,跟普通 ele.clientWidth 含义不同。

通常情况下,ele.clientWidth 指的是 ele,作为包含块,给于内部元素的一个视口,ele 的尺寸和 clienWidth 是相关的,详情戳clientWidth

按照这个逻辑,我们应该计算 html 的包含块,也就是初始包含块的 clientWidth,但是似乎没有接触初始包含块的接口,仅仅知道,在桌面端,他的尺寸和视口一致;

所以当我们设置

   html {
height: 100%;
width: 100%;
}

其实,是将 html 的宽高设置为初始包含块的宽高,等于视口的宽高。

关于 body 的这个属性,如果消除了默认的 margin ,则和上方是相等的:

document.body.clientWidth

document.body.clientHeight

但是如果给 body 显示设置了宽高,返回的就不一定是视口的宽高了,这是普通元素的特性。

另外,浏览器窗口大小(浏览器窗口,自然是包括滚动条的):

window.innerWidth

window.innerHeight

屏幕大小(设备像素,不常用,其实就是分辨率),即使浏览器缩小了,这个值也不会变,是屏幕。

screen.width

screen.height

2、文档大小(包含了超出文档的溢出部分)

document.documentElement.scrollHeight

document.documentElement.scrollWidth

文档大小(不包含超出文档的溢出部分,如果 overflow:hidden,那么和上面的是一致的,但这个属性耗性能)

document.documentElement.offsetHeight

document.documentElement.offsetWidth

3、文档滚动的大小

兼容移动端需要用:

window.pageXOffset

window.pageYOffset

别名 scrollX / scrollY ,IE 不兼容别名,兼容 pageXOffset / pageYOffset,但是 IE9 之前的两个都不兼容;

另一种常用的写法:

document.documentElement.scrollTop;

document.documentElement.scrollLeft;

可写可读,缺点是不兼容移动端;

4、元素相对于视口的位置

ele.getBoundingClientRect(); //包含4 个属性:left、top、right 和bottom

5、元素的大小(border-box,不包含溢出部分,包括溢出的用 )

ele.offsetWidth;

ele.offsetHeight;

元素的大小(border-box 包括溢出的部分,如果溢出隐藏,和上面值一致 )

ele.scrollWidth;

ele.scrollHeight;

6、元素滚动的大小,(应该是相对于包含块) 可写(当然包含块要处于溢出状态才行)

ele.scrollTop;

ele.scrollLeft;

  html.scrollTop 相对于初始包含块,所以上文 html.scrollTop 计算文档相对于视口的偏移就是这个道理

7、元素相对于文档的位置(貌似没有原生的 API,推算就是,相对于视口的偏移 + 文档相当于视口的滚动)

ele.getBoundingClientRect().top+document.documentElement.scrollTop;

ele.getBoundingClientRect().left+document.documentElement.scrollLeft;

8、计算滚动条的宽度

function getScrollbarWidth() {
var para = document.createElement('p'),
styles = {
width: '100px',
height: '100px',
overflowY: 'scroll'
},
i, scrollbarWidth;
for (i in styles) { para.style[i] = styles[i]; };
document.body.appendChild(para);
scrollbarWidth = para.offsetWidth - para.clientWidth;
document.body.removeChild(para);
return scrollbarWidth;
}

参考资料:

JavaScript高级程序设计-第3版-中

https://yq.aliyun.com/ziliao/52315

js 常用 DOM 元素宽高的更多相关文章

  1. js获取隐藏元素宽高的方法

    网上有一些js获取隐藏元素宽高的方法,但是可能会存在某些情况获取不了. 例如: <!DOCTYPE html> <html lang="en"> <h ...

  2. Vue动态设置Dom元素宽高

    需求: slider侧边栏是宽度是动态的,使用jquery可以操作dom元素,设置宽高,但vue是避免操作dom的 <template> <div class="slide ...

  3. 原生JS获取元素宽高实践详解

    开篇的话 任何不是亲身实践中求得的知识,都不是属于你的.任何求得的知识不去时常温习运用,也不是属于你的. 记录由来 在做个上拉广告功能中遇到了一个"理所当然"觉得对的用法,慢慢才排 ...

  4. js获取精确的元素宽高(普通获取高度会有误差)

    当js获取元素宽高时, 并不是一个精确的数字,如果想获取真正的宽高大致方法如下 var oStyle = obj.currentStyle ? obj.currentStyle : window.ge ...

  5. CSS子元素居中(父元素宽高已知,子元素未知)

    <style> .container{width:400px; height:400px; position:relative;} .center{position:absolute; l ...

  6. JS获取图片实际宽高及根据图片大小进行自适应

    JS获取图片实际宽高,以及根据图片大小进行自适应  <img src="http://xxx.jpg" id="imgs" onload="ad ...

  7. JS1 js获取dom元素方法

     js获取dom元素方法  1.通过ID选取元素(getElementById) 1)使用方法:document.getElementById("domId")         其 ...

  8. JS获取图片实际宽高

    JS获取图片实际宽高,以及根据图片大小进行自适应 <img src="http://xxx.jpg" id="imgs" onload="ada ...

  9. 关于Echarts的原生js获取DOM元素与动态加载DOM元素的冲突问题

    1.前言: 最近在做的看板项目,因为需要循环加载后台数据,并且用Echarts做数据呈现,所以jQuery和angular等库统统靠边站,Echarts用的是原生js获取DOM元素,至于诸多不兼容等深 ...

随机推荐

  1. EasyUI combobox的panelHeight自动高度

    在使用EasyUI的时候,有时会用到combobox组件,这里的记录数不是很固定,设置为auto可能会被挡住,设置固定高度时,option很少时,也很丑 所以这里给出我自己自动调整combobox的p ...

  2. laravel多条件查询,及分页

    $res = DtkModel::where('ID','>','1')->select("ID")->get()->paginate(20);//不成立 ...

  3. AESDK关于AEFX_CLR_STRUCT的用处

    主要是在初始化UI值的时候遇到问题,一直报错 但确实没有用到ui_width,ui_height...,仔细检查例子工程发现,少了一个AEFX_CLR_STRUCT宏 AEFX_CLR_STRUCT其 ...

  4. JMeter学习笔记(二)

    3.JMeter测试计划要素 JMeter中一个脚本即是一个测试计划,也是一个管理单元.JMeter的请求模拟与并发数(设置线程数,一个线程代表一个虚拟用户)设置都在脚本文件中一起设置. 要素一:脚本 ...

  5. 关于HashMap初始化容量问题

    使用阿里云代码规范插件扫描后出现以下提示: hashmap should set a size when initalizing,即hashmap应该在初始化时设置一个大小 在网上搜到一篇讲解(htt ...

  6. C++static关键字用法

    一.static的作用有三种:限制变量或函数作用域.保持变量内容的持久.默认初始化为0 1.被static关键字修饰的全局函数或者变量具有文件作用域,即只在当前文件中可见. 2.被static修饰的变 ...

  7. 阿里云高速maven库

    <repository> <id>alimaven</id> <name>aliyun maven</name> <url>ht ...

  8. [Kernel]理解System call系统调用

    转自:http://os.51cto.com/art/200512/13510.htm 现在,您或许正在查看设备驱动程序,并感到奇怪:“函数 foo_read() 是如何被调用的?”或者可能疑惑: “ ...

  9. Linux用ssh登陆出现“Too many authentication failures for root”

    vim /etc/ssh/sshd_config 最后参数 UseDNS no AddressFamily inet PermitRootLogin yes SyslogFacility AUTHPR ...

  10. 2015 Multi-University Training Contest 3 1001 Magician

    Magician Problem's Link: http://acm.hdu.edu.cn/showproblem.php?pid=5316 Mean: n个数,2种操作,1是单点更新,2是询问区间 ...