优惠券活动
2018-05-19
1052浏览量
有时候在获取浏览器、元素、屏幕的尺寸,傻傻分不清。为了让自己清晰认识,能够快速确定自己需要哪个属性,现在把这些尺寸属性整理了一下。
浏览器视口(viewport)宽度(单位:像素),如果存在滚动条则包括它。
let viewportWidth = window.innerWidth;
let viewportHeight = window.innerHeight;
window.innerWidth
和window.innerHeight
是只读属性,无默认值。
如果HTML中添加了以下内容,则页面在移动端访问的时候,视口宽高始终与逻辑分辨率一致。
否则,移动端浏览器会在一个通常比屏幕更宽的虚拟”窗口“(视口)中渲染页面。
<meta name="viewport" content="width=device-width, initial-scale=1, minimum-scale=1, maximum-scale=1, user-scalable=no" />
整个浏览器窗口的高度(单位:像素),包括侧边栏(如果存在)、窗口镶边(window chrome)和窗口调正边框(window resizing borders/handles)。
let outerWidth = window.outerWidth;
let outerHeight = window.outerHeight;
window.outerWidth
和window.outerHeight
是只读属性,无默认值。
在使用桌面端浏览器的模拟移动设备查看网页时,这两个属性,依然指的是桌面端浏览器窗口的宽高。
元素内部宽 = width + padding-left + padding-right - 竖直滚动条宽度
元素内部高 = height + padding-top + padding-bottom - 横向滚动条高度
let clientWidth = element.clientWidth;
let clientHeight = element.clientHight;
元素布局宽 = width + padding-left + padding-right + 竖直滚动条宽度 + border-left + border-right
元素布局高 = height + padding-top + padding-bottom + 横向滚动条高度 + border-top + border-bottom
let offsetWidth = element.offsetWidth;
let offsetHight = element.offsetHight;
元素的内容宽高,包括由于溢出导致内容在屏幕上下不可见的内容。
let scrollWidth = element.scrollWidth;
let scrollHeight = element.scrollHeight;
屏幕分辨率宽高。如果是移动设备,则返回逻辑分辨率宽高。
let screenWidth = window.screen.width;
let screenHeight = window.screen.height;
减去比如Windows的任务栏等界面特性的屏幕的可用宽高。如果是移动设备,则返回逻辑分辨率宽高。
let availWidth = window.screen.availWidth;
let availHeight = window.screen.availHeight;
版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。
集结各类场景实战经验,助你开发运维畅行无忧