在移动设备上的页面开发 , 首先需要搞清楚的就是viewport
, 这是适配和响应各种不同分辨率的移动设备的前提条件
概念
通俗地讲 , 移动设备上的viewport是指设备的屏幕上能用来显示网页的那块区域
关于像素(px)
这是css当中常见的定义像素值的单位
但是这个值并不能完全等同于设备的物理像素
因为页面是可以被缩放的 , 如果缩放到2倍
那么1px在页面上就会占用2个物理像素的距离
移动设备的3个viewport
layout viewport
它的宽度是大于浏览器可视区域的宽度的
宽度值可以通过document.documentElement.clientWidth
来获取
还需要一个viewport来代表浏览器可视区域的大小
visual viewport
它的宽度可以通过window.innerWidth
来获取
现在已经有两个viewport了 , 但是浏览器还觉得不够 , 因为越来越多的网站都会为移动设备进行单独的设计 , 所以还必须要有一个能完美适配移动设备的viewport
完美适配指的是 :
- 不需要用户缩放和横向滚动条就能正常地查看网页的所有内容
- 显示的文字大小合适 , 不会因为在高密度像素的屏幕里显示得太小而无法看清 . 当然不只是文字 , 其他元素的大小也是同样的道理
ideal viewport
这是移动设备的理想viewport , 它并没有一个固定的尺寸 , 不同的设备有不同的尺寸
例如所有iphone设备的ideal viewport的宽度都是320px , 无论它的屏幕宽度是320还是640
安卓设备则比较复杂 , 有很多不同的值
页面中元素大小如果根据ideal viewport来适配 , 则不会出现在像素密度太高的屏幕上 , 元素显示太小的问题了
利用meta标签对viewport进行控制
移动设备默认的viewport是layout viewport , 但是在进行移动设备网站的开发时 , 我们需要的是ideal viewport
通常需要在head标签当中添加
1 | <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no" /> |
属性说明 :
width
- 控制viewport宽度 , 可以指定一个值 , 或者特殊的值 , device-width为设备的宽度height
- 与width相对应 , 指定高度 , 这个属性并不重要 , 很少使用initial-scale
- 初始缩放比例 , 比如1.0maximum-scale
- 允许用户缩放到的最大比例minimum-scale
- 允许用户缩放到的最小比例user-scalable
- 用户是否可以手动缩放 , 值为yes或者no
要得到ideal viewport只需要把width设置为device-width即可
需要说明的是 , 有关缩放的属性都是相对于ideal viewport进行缩放的
所以如果只写
1 | <meta name="viewport" content="initial-scale=1" /> |
也可以达到ideal viewport的效果
视区的相关单位
vw
- 相对于视区的宽度 , 视区总的宽度为100vwvh
- 相对于视区的高度 , 视区总的高度为100vhvmin
- 相对于视区的宽度与高度当中较小的一个vmax
- 相对于视区的宽度与高度当中较大的一个
比如某种情况下视区的宽度为1000px
div的width为2vw , 那么这个div的实际显示宽度就是20px
高度同理
实际应用
- 弹性布局
实践当中 , 如果我们需要把两个元素横向并排布局
设置浮动之后 , 分别指定宽度为25%与75%
与指定宽度为 25vw和75vw
相比并没有什么优势 , 实际的作用也是一样的
在布局方面要发挥更大的作用 , 需要结合一个CSS的函数calc
就是calculate的缩写
这个函数的作用是执行表达式的计算
如果不使用这个函数 , 我们通常是需要使用一些预处理工具 , 比如sass , 才能在css当中编写表达式
让预处理工具在打包css代码的过程中完成这个计算
但是这样终究比较局限 , 因为视区的宽度高度是页面实际渲染的时候才确定的
如果涉及到视区的计算 , 则无法完成
回到最初的问题 , 按照宽度的百分比横向排列两个div
直接用百分比当然是可以的 , 但是如果这个元素有 border margin padding当中的任意一个 , 右边的div就会被挤到下一行
( 如果是单个元素宽度100%的话 , 盒子会被撑破 , 超出父元素的宽度 )
这时候我们就可以用calc函数配合vw来解决这个问题
1 | .left,.right { |
出于兼容性的考虑 , 最好给calc加上
-webkit-
和-moz-
的前缀
- 弹性字体
在响应式布局中 , 字体的大小最好是能跟随视区的大小进行自动调整
才能达到比较好的体验
可以采用如下方式
1 | :root { |
:root
伪类匹配DOM文档树的根元素
补充说明
使用视区的相关单位的值对应的属性 , 不会跟随页面的缩放变化
比如第二个例子当中的字号
在放大页面的时候 , 文字的大小是不会改变的