如下结论若有错误,欢迎指正html
在切入正题以前,先了解下window 和document这两个大对象浏览器
咱们熟知 JavaScript的组成以下图所示:3d
window对象和document对象分别属于哪一个分支下面呢?htm
发现: 在控制台打印出的document对象和window.document打印出来的对象是一致的对象
缘由是由于: 日常咱们以document开头的各类API 实际上都是省略了windowblog
如今对于window和documen有了初步理解以后ip
如今抛出如下几个属性rem
window.outerHeight ? window.innerHeight? document.documentElement.clientHeight ? document.body.clientHeight? offsetHight? scrolHeight? 脑壳瞬间123文档
那么就一个个攻破吧浏览器兼容性
顾名思义,从window开始,咱们知道window属于BOM范围,BOM指的是浏览器对象模型,存储浏览器的各类信息个API,因此
window.outerHeight
便是整个浏览器的外边高度(包含了导航栏,横向滚动条等)
windwo.innerHeight
浏览器除去导航栏,横向滚动条剩下的DOM的视口大小
经检验:
在移动端浏览器中: window.outerHeight = windwo.innerHeight ;
在移动端中 二者且是设备的逻辑像素(也叫作CSS像素)
在PC浏览器中: window.outerHeight ≠ windwo.innerHeight ;
浏览器兼容性: 兼容到IE8
从document开始,那么描述的是文档对象模型这个对象的相关属性和API,因此
document.documentElement.clientHeight
文档对象模型中HTML标签的高度
document.body.clientHeight
文档对象模型中body标签的高度
经检验:
在移动端中 document.documentElement.clientHeight = document.body.clientHeight
在PC端中 document.documentElement.clientHeight ≠ document.body.clientHeight
兼容性: 兼容到IE6
一般咱们当即offset就是偏移的意思,即页面滚动,从页面开始到滚动到的位置的偏移高度
滚动的高度,包含页面没有显示出来的,页面的总体高度
理解了以上的几点以后,脑壳忽然想到移动端设配的REM是经过获取docuemt.documentElement.clientWidth来动态改变html标签的font-size的大小,该边font-size的大小的缘由是由于会用到REM来匹配1rem 等于HTML元素的font-size的大小,这时候脑壳又想到REM? EM ? PX?
设备中的最小显示单位,不可改变
以元素外层的父元素的font-size做为参照基准,元素的 1em = 元素的父级元素的font-size的大小
以HTML标签的font-size大小为参照基准,元素的1rem = html变迁的font-size大小
晚点画一张图,表示关系。