深入理解viewport及相关属性的关系

诸葛靓
• 阅读 2670

标题想了半天,最后潦草的取了【深入理解*】,可能有些童鞋们看完觉得没有深入理解,那。。。

话不多说,上正题,本文主要是加深对viewport3个视口的了解,以及相关的属性作用于哪些视口上,希望对大家有帮助吧

概括总结:布局视口最有用,用到的几乎都是这个。理想视口是浏览器定义的最佳的布局视口的尺寸,缩放的最大最小情况是基于这个计算的。视觉视口受缩放影响,一般情况不大用。

大概了解viewport童鞋们应该知道,viewport有3种

  1. 布局视口(layout viewport)
  2. 视觉视口(visual viewport)
  3. 理想视口(ideal viewport)

对应相关的属性有5个

  1. width:设置布局视口的宽度为特定的值
  2. initial-scale:设置页面的初始缩放程度和布局视口的宽度。
  3. minimum-scale:设置最小缩放程度(范围0.1 - 10)
  4. maximum-scale:设置最大缩放程度(范围0.1 - 10)
  5. user-scalable:是否阻止用户进行缩放

深入理解viewport及相关属性的关系

为啥没有理想窗口:因为理想窗口是浏览器自己定义的,不同浏览器设备的理想窗口不一致是很正常的。

深入理解viewport及相关属性的关系

布局视口

移动设备的通常的宽度在240到640像素之间,但是很多桌面的网站的宽度都在800像素以上。一个35%的sidbar在桌面看起来很正常,在手机上则会非常的窄。为了解决这个问题。很多移动端浏览器的厂商都将视口的宽度设计的比屏幕尺寸宽很多,从768到1024不等,但常见的宽度是980px。

可以用document.documentElement.clientWidth/clientHeight取得对应的值

下图是在没有加viewport meta的时候,对应移动端的宽度(iphone 8p上也是980)

深入理解viewport及相关属性的关系

在浏览器碰到一个没有做移动端优化的网站时候,浏览器会尽可能缩小网站让用户看到网站的全貌。

viewport meta里面的width是用来设置layout viewport的,除了常见的device-width,还能设置成固定数值,比如600。

CSS布局会根据布局视口计算,并被它约束。

如下图,粉色条的宽度是根据600 * 30% = 180

深入理解viewport及相关属性的关系

initial-scale也是用来设置layout viewport的,它和minimum-scale和 maximum-scale不一样。

布局视口宽度 = 理想视口宽度 / initial-scale, 所以下图中布局视口的宽度等于106

深入理解viewport及相关属性的关系

视觉视口

视觉视口是指用户正在看到的网站的区域。用户可以通过缩放来操作视觉视口,同时不会影响布局窗口

一般情况下,视觉视口对开发人员并不重要,但是如果实在要用,可以用window.innerWidth/Height可以获取当前视觉适口的值(安卓webkit2和代理浏览器会有问题)
深入理解viewport及相关属性的关系

理想视口

在讲布局视口的时候,提到过布局视口的默认宽度一般是980左右,以适应桌面网页的宽度,但这在移动端并不是一个理想的宽度,所以浏览器厂商都引入了理想视口的概念。

理想视口对设备来说是最理想的布局视口尺寸,拥有最理想的浏览和阅读的宽度。

理想视口是浏览器定义的,不是设备或操作系统的工作。所以同一个设备上的不同浏览器可能具有不同的理想适口宽度。

理想视口宽度会随着设备改变转向 (早期的safari例外,可以用initial-scale=1解决,我刚刚用iphone 8p试了,旋转设备后理想适口自动换了)

可以用screen.width/height 返回理想视口的尺寸。(兼容性不好。。。)

以下两种方式都能将布局窗口的宽度设置成理想窗口的宽度,但是第一种方式在早期safari的设备旋转后不会变化,第二个在IE 10下宽度不正确,所以第三种才是完美的mata视口

<meta name="viewport" content="width=device-width">

<meta name="viewport" content="initial-scale=1">

<meta name="viewport" content="width=device-width, initial-scale=1">

所有的缩放都是基于理想视口宽度的 maximum-scale和minimum-scale都是根据理想视口定的,和布局视口的宽度并无关系。

下图中,理想视口宽度是320px,布局视口设置成160px,截图是我放大到最大的时候(10倍),对应视觉窗口的宽度是32px(2个粉红的宽度),即 理想视口宽度/10倍的宽度,而不是布局视口/10的宽度(16px)

深入理解viewport及相关属性的关系

参考:
书本《移动web手册》
链接:https://www.quirksmode.org/mo...

点赞
收藏
评论区
推荐文章
Wesley13 Wesley13
4年前
java经典50题
JAVA基础编程练习50题本文对50道经典的java程序题进行详细解说,对于初学者可以跳过一些逻辑性太强的题目,比如第一题用到了方法的递归,初学者可能不理解,最好先看那些有if、for、while可以简单解决的程序题!但是,对于比较深入学习过的同学,还是希望可以一口气就看完,这是比较全面思维锻炼!【程序1】题目:古典问题:有一对兔子,从
Android经典面试题,也可以提升综合能力
基础问题相关1、接口的意义百度2、抽象类的意义百度3、内部类的作用乐视4、Java虚拟机的特性百度乐视5、哪些情况下的对象会被垃圾回收机制处理掉美团小米6、进程和线程的区别猎豹美团7、java中和equals和hashCode的区别乐视8、HashMap的实现原理美团9、stringst
Stella981 Stella981
4年前
Graphics View绘图架构(二)
GraphicsView结构的主要类包括:视图类QGraphicsView、场景类QGraphicsScene、和各种图形项类(基类都是QGraphicsItem)1\.QGraphicsView用于观察一个场景的物理窗口  场景小于视图,整个场景在视图中可见;当场景大于视图时,试图自动提供卷滚条  QGraphicsView的视口坐标等
Stella981 Stella981
4年前
Mybateis mapper 接口 example 用法
注意:希望通过此篇文章分享可以使大家对mapper接口以及example用法更加深入理解MyBatis的Mapper接口以及Example的实例函数及详解一、mapper接口中的
Stella981 Stella981
4年前
Flutter 可滚动组件:简介
前言当组件内容超过当前显示视口(ViewPort)时,如果没有特殊处理,Flutter则会提示Overflow错误。为此,Flutter提供了多种可滚动组件(ScrollableWidget)用于显示列表和长布局。可滚动组件都直接或间接包含一个Scrollable组件,它们包括一些共同的属性,接口如下:Scrollable({
西瓜视频广告宣传呈现方式
西瓜视频想来大伙儿早已了解不己常见于收看各种各样视頻,今日也为大伙儿详尽解读一下掌握西瓜视频。西瓜视频是巨量引擎集团旗下的智能推荐视频网站,由今日今日头条卵化。西瓜视频根据人工智能技术协助每一个人察觉自己喜爱的视頻,并协助视頻写作大家轻轻松松地为全球共享自身的视頻著作。西瓜视频广告是今日头条在短视频营销行业关键经营的商品,现阶段称之为是总流量的价值洼地,不但
Easter79 Easter79
4年前
TiDB 在新乐视云联“月光宝盒”项目中的应用与实践
公司介绍2018年,乐视云计算有限公司品牌升级为新乐视云联,新乐视云联是新乐视上市体系中核心业务版块之一,负责新乐视体系所有基础设施服务和云计算服务。新乐视云联围绕视频云和物联云两大方向开展业务,致力成为领先的家庭互联智能娱乐云技术提供者,以物联云为核心创造更智能的家居社区解决方案。新乐视云联在视频行业有强大的技术储备,在视频领域中的点播
Easter79 Easter79
4年前
SVG的几个标签元素
defssvg允许我们定义以后需要重复使用的图形元素。建议把所有需要再次使用的元素定义在defs元素里面。这样做可以增加svg内容的易读性和可访问性。在defs元素定义的元素不会直接呈现。你可以在你的视口的任意地方利用<use元素呈现这些元素。用法:类别:容器元素,结构元素允许的内容物: 任意数量、任意
Stella981 Stella981
4年前
SVG的几个标签元素
defssvg允许我们定义以后需要重复使用的图形元素。建议把所有需要再次使用的元素定义在defs元素里面。这样做可以增加svg内容的易读性和可访问性。在defs元素定义的元素不会直接呈现。你可以在你的视口的任意地方利用<use元素呈现这些元素。用法:类别:容器元素,结构元素允许的内容物: 任意数量、任意
“视界”尽在眼前,海纳视联大模型来了!
11月10日—13日,以“数字科技焕新启航”为主题的2023数字科技生态大会在广州举办。会议期间,在数字生活与天翼视联合作论坛上,重磅发布了由天翼云科技有限公司、天翼数字生活科技有限公司和天翼视联科技有限公司联合研发的视联行业大模型——海纳视联大模型,为视联行业智能化发展按下加速键。
一行代码修复100vh bug | 京东云技术团队
你知道奇怪的移动视口错误(也称为100vhbug)吗?或者如何以正确的方式创建全屏块?一、100vhbug什么是移动视口错误?你是否曾经在网页上创建过全屏元素?只需添加一行CSS并不难:.mypageheight:100vh1vh是视口高度的1%,正是我们