千锋教育-做有情怀、有良心、有品质的职业教育机构

手机站
千锋教育

千锋学习站 | 随时随地免费学

千锋教育

扫一扫进入千锋手机站

领取全套视频
千锋教育

关注千锋学习站小程序
随时随地免费学习课程

当前位置:首页  >  技术干货  > web页面中的布局位置到底是什么?

web页面中的布局位置到底是什么?

来源:千锋教育
发布人:xqq
时间: 2023-10-11 17:42:46 1697017366

一、web页面中的布局位置

viewport 是浏览器视口,代表浏览器的可视区域,也就是浏览器中用来显示网页的那部分区域。在桌面电脑上,由外到内分为显示器窗口、浏览器窗口、浏览器视口 (viewport)、 元素。

显示器窗口

显示器窗口就是你的显示器屏幕的可见区域。显示器的分辨率,描述的是显示器窗口的设备像素,又叫做物理像素,通过 screen.width 来表示水平方向的物理像素,screen.height 来表示垂直方向的物理像素。比如一台分辨率为 1920 * 1080 的显示器,它的 screen.width 为 1920,screen.height 为 1080。screen.width 和 screen.height 是固定的,不可以改变。

浏览器窗口

浏览器窗口就是浏览器中用来显示网页的可见区域,不包括工具栏的部分,但是包括水平滚动条和垂直滚动条 (只包括滚动条本身所占的像素,不包括已滚动的网页部分)。

浏览器视口

viewport 就是浏览器视口,浏览器视口和浏览器窗口类似,只不过不包括水平滚动条和垂直滚动条。如果网页里没有滚动条,则浏览器视口和浏览器窗口的大小一样。通过 document.documentElement.clientWidth 来表示浏览器视口水平方向能够显示的 CSS 像素数,document.documentElement.clientHeight 来表示浏览器视口垂直方向能够显示的 CSS 像素数。如果没有滚动条,document.documentElement.clientWidth 和 window.innerWidth 相等。如果有滚动条,window.innerWidth = document.documentElement.clientWidth + 垂直滚动条所占的宽度。document.documentElement.clientWidth 和 document.documentElement.clientHeight 是可变的,通过拉伸或者缩放浏览器可以改变。

元素

HTML 文档中, 元素是文档根元素,通过 document.documentElement 来表示 元素。 元素所占的 CSS 宽度和高度,用 document.documentElement.offsetWidth 和 document.documentElement.offsetHeight 来显示。

缩放浏览器

通过百分比缩放浏览器的时候,并没有改变浏览器的物理尺寸,但是改变了 CSS 像素的物理尺寸。viewport 所能够展示的 CSS 像素数也会发生改变,因此 document.documentElement.clientWidth 和 window.innerWidth 就会改变。

比如我们把显示器放大到 200%,网页中的元素尺寸都放大一倍,但是元素的 CSS 像素值不会改变。比如某个元素的 width: 100px;,不管是浏览器放大显示还是缩小显示,该元素的 CSS 像素是不会变的,永远都是 width: 100px;,变化的是该元素在显示器上所占的物理尺寸。当浏览器放大 200% 显示网页的时候,1px CSS 像素的物理尺寸也会放大一倍。

举例子:

点击浏览器的放大按钮放大到 200% 显示网页的时候,虽然浏览器的物理尺寸没有变化,但是 1px CSS 像素的物理尺寸扩大了一倍,因此浏览器 viewport 能够展示的 CSS 像素数就会缩小一倍。因此不缩放时,viewport 为 1000px,放大 200% 之后,viewport 为 500px,也就是说放大后 viewport 水平方向能够展示的 CSS 像素数为 500px。同理,点击浏览器的缩小按钮缩小到 50% 显示网页的时候,viewport 为 2000px,也就是说缩小后 viewport 水平方向能够展示的 CSS 像素数为 4000px。

延伸阅读:

二、网页可见区域是什么

网页可见区域宽: document.body.clientWidth;

网页可见区域高: document.body.clientHeight;

网页可见区域宽: document.body.offsetWidth (包括边线的宽);

网页可见区域高: document.body.offsetHeight (包括边线的高);

网页正文全文宽: document.body.scrollWidth;

网页正文全文高: document.body.scrollHeight;

网页被卷去的高: document.body.scrollTop;

网页被卷去的左: document.body.scrollLeft;

网页正文部分上: window.screenTop;

网页正文部分左: window.screenLeft;

屏幕分辨率的高: window.screen.height;

屏幕分辨率的宽: window.screen.width;

屏幕可用工作区高度: window.screen.availHeight;

对块级元素来说,offsetTop、offsetLeft、offsetWidth 及 offsetHeight 描述了元素相对于 offsetParent 的边界框

声明:本站稿件版权均属千锋教育所有,未经许可不得擅自转载。
10年以上业内强师集结,手把手带你蜕变精英
请您保持通讯畅通,专属学习老师24小时内将与您1V1沟通
免费领取
今日已有369人领取成功
刘同学 138****2860 刚刚成功领取
王同学 131****2015 刚刚成功领取
张同学 133****4652 刚刚成功领取
李同学 135****8607 刚刚成功领取
杨同学 132****5667 刚刚成功领取
岳同学 134****6652 刚刚成功领取
梁同学 157****2950 刚刚成功领取
刘同学 189****1015 刚刚成功领取
张同学 155****4678 刚刚成功领取
邹同学 139****2907 刚刚成功领取
董同学 138****2867 刚刚成功领取
周同学 136****3602 刚刚成功领取
相关推荐HOT