移动端web开发必须了解的viewport

之前也或多或少也接触过移动端,写移动端页面的时候,总是会在head标签里加这么一行代码

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

不管知不知道背后的原理,反正加这么一句话后,网页宽度就与屏幕宽度完美一致了。直到最近做的一个项目,需要将已经写好的PC页面再重构一份移动端页面,意外的发现,原来PC上的页面在手机上布局没有乱,而且没有出现滚动条,然后我加上了上面那句代码,滚动条又出现了,我想是时候真正认识一下viewport了。
而在理解viewport的时候,看了大量的博客,越看越糊涂,最后综合多人的博客,才得出自己的理解,而在理解viewport之前,先要理解下面这五点

1.屏幕分辨率

屏幕分辨率:屏幕分辨率是一个物理属性,表示一个屏幕上有多少个像素点,如iphone 6 的分辨率是1334px ×750px,表示屏幕可以分成1334*750个像素点。

2.屏幕尺寸

这个很容易理解,只需要知道我们说的手机5.5寸屏,说的是对角线的长度。

3.屏幕像素密度 dpi/ppi

每单位尺寸上,有多少个物理像素点。一个手机给你,屏幕分辨率是固定的,屏幕的尺寸是固定,所以屏幕像素密度也是固定的。

4.css像素

css像素不是绝对单位,是相对单位。在PC上,1px与1物理像素是一致的,所以如果你的笔记本屏幕分辨率是1366px x 768px 的,你给body width:1366px,刚好撑满屏幕。但事实上css里的1px并不总是等于1物理像素。在移动端,如iphone3,它的分辨率为320x480,在iphone3上,一个css像素确实是等于一个屏幕物理像素的。后来随着技术的发展,移动设备的屏幕像素密度越来越高,从iphone4开始,苹果公司便推出了所谓的Retina屏,分辨率提高了一倍,变成640x960,但屏幕尺寸却没变化,这就意味着同样大小的屏幕上,像素却多了一倍,这时,一个css像素是等于两个物理像素的。此外,屏幕缩放也会影响到这个关系。

5.device-width(这里的width是csspx)

这个东西,曾经困扰了我很久,单单去理解viewport,并不是很复杂,但是当你决定要把一系列知识搞清楚的时候,任何一个环节想不通都会让你抓狂。device-width从字面意思上即设备宽度,但是iphone 6的分辨率为1344px750px,而iphone 6的device-width为375px,iphone 5的device-width为320px,很明显device-width与分辨率不是一比一的关系,那么它与移动设备的物理像素,尺寸,单位像素密度又何关系呢?在回答这个问题之前,我们先想,如果device-width与物理像素一致会发生什么?
iphone 3的分辨率320px
480px,iphone 4的分辨率翻了一倍,但是iphone 3和iphone 4的尺寸却是一样的。所以如果device-width与物理像素为1:1的关系,那么原来为iphone 3开发的网页中,有一个100px的div,大约占了屏幕的1/3,而在iphone 4上,只占了屏幕的大约1/6,这显然不行,原来满屏的东西,在iPhone4上只占了一半。所以现在就要解决这个问题
方案1.:再为iphone4写一套css,原来100px的东西,现在写200px
方案2 :既然屏幕尺寸没变,那就device-width也不变,保持320px.显然此时1px等于2个物理像素
经过简单分析,我们应该采取方案二。因为移动端的一个很大特点就是手机分辨率五花八门,按照方案1,岂不是要为每一种写一套,而且分辨率的变化程度远大于屏幕尺寸的变化程度,如上iphon3与iphone4.对于俩个尺寸大小差不多的手机,同一个东西大小看起来就差了很多,用户体验就会很不好。所以我们想要实现的一个效果就是100px的东西,在尺寸差不多大的设备上看起来都差不多大,
那么device-width应该多大呢?接下来,我们具体的看一下device-width应指是如何计算出来的。
根据设备的dpi,对应着一个转换系数(以屏幕分辨率宽度=device-width=320px的设备为标准),如iphone4 dpi对应的的转换系数为2,所以iphone 4的device-width=640px/2=320px,iphone 6的转换系数也为2,device-width=750px/2=375px.假设,折转换系数为m,则1csspx等于m倍的物理像素,这里转换系数都是依据dpi的,不能仅根据物理像素的比例关系,因为iphone3和iphone4的尺寸刚好一样,如果iphone4的屏幕分辨率扩了一倍,而尺寸也扩大了一倍,那么在刚才device-width=物理像素的假设为真时,100px的东西在iphone4与iphone 3的大小应该是一致的,所以尺寸的变化也会影响到这个比例关系,所以同时考虑物理像素和屏幕尺寸不好比较,所以统一用dpi,就没这个问题了。

6 viewport

终于到了神秘的viewport,按照前面的理解思路,理解下面的viewport的要很容易了。如果这个世界上没有电脑,只有手机,上面通过理解device-width,以及1csspx与物理像素的关系,对开发移动网页就够了,通过转换系数。设备分辨率想必物理分辨率的种类已经少了很多,基本就320,360,375,414这些。但是很明显,电脑出现的比手机要早的多,前几年开发的时候,我们基本不考虑移动端。现在不一样了,甚至有时候移动端比PC端都要重要。
这样一来,对于原来在电脑上的页面(没有做移动端处理),在手机上打开会肯定会出现滚动条,比如在pc上500px的东西,在iphone4的满屏才320px,所以肯定会出现滚动条,而特别时对于基于浮动的布局,整个页面都会乱掉。
所以手机浏览器上提出了viewport,网页是放在viewport之上的,而给它一个默认的很大宽度的值,很多设备是980px,这样原来在pc上的页面在移动端布局就不会乱掉,然后正如开头提到的,甚至连滚动条都没有。(这也是一个让我困惑过的地方)因为按照上面的理解,此时应该会出现滚动条,但是对pc端容器小于980px的布局基本不乱,后来发现的确应该是这样。如果你不加meta标签那句代码,浏览器会自动缩放,缩放到让其不出现滚动条,这也是为什么东西看起来都那么小的原因,但是如果你显示的这样设置

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

网页就会出现滚动条,而如果一个div的宽度刚好与device-width一样宽,那么这个div刚好占满手机的一屏。但是仍然会出现滚动条,这个现象就像,在pc端,你的屏幕分辨率宽1366px,那么一个1366px的div会满屏,但是如果你把浏览器缩小后,这个div仍是1366px,但是可视区域小与1366px了,通过拖动滚动条,你可以看到完整的东西。
所以当我们将viewport的width设置为device-width时候,网页宽度就与设备宽度一致,html/body是继承viewport的宽度,而不是device-width。
接下来,我们简单说下关于viewport自己的东西,据很多博客主解释,viewport其实有三个,一个layout-viewport,我们meta标签设置的也是layout-viewport,还有一个visual-viewport,还有一个ideal-viewport,就是layout-viewport等于device-width的时候。关于这个viewport深层次的理解,可以参考这里
 其实理解到这里,到底有几个viewport,对我们已经不是很重要了,我们只需只道手机浏览器是把网页放在viewport上的,viewport不管你设不设置,都客观存在。
所以,移动端开发必须加加入开头我提到的那段代码,让你的网页宽度与屏幕保持一致。一个好的设计就像这样,背后包含了大量的知识,但是用户用它的时候,自然到不需要了解它背后的原理。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 211,348评论 6 491
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,122评论 2 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 156,936评论 0 347
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,427评论 1 283
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,467评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,785评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,931评论 3 406
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,696评论 0 266
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,141评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,483评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,625评论 1 340
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,291评论 4 329
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,892评论 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,741评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,977评论 1 265
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,324评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,492评论 2 348

推荐阅读更多精彩内容