传统百分比布局和flex布局的小瑕疵:
- 页面文字大小固定。
- 主要针对于宽度布局,高度一般写死。
- 屏幕发生变化的时候元素内容不会等比缩放。
那么,页面布局文字能否随着屏幕大小变化而变化?
流式布局和flex布局主要针对于宽度布局,那高度如何设置?
怎么样让屏幕发生变化的时候元素高度和宽度等比例缩放?
四. 移动端布局:rem布局
1. rem单位
rem (root em)是一个相对单位,类似于em,em是父元素字体大小,不同的是rem的基准是相对于html元素的字体大小,所有浏览器均已支持rem。
比如,根元素(html)设置font-size=12px; 非根元素设置width:2rem; 则换成px表示就是24px。
/* 根html 为 12px */
html {
font-size: 12px;
}
/* 此时 div 的字体大小就是 24px */
div {
font-size: 2rem;
}
父元素文字大小可能不一致,但是整个页面只有一个html,可以很好来控制整个页面的元素大小。
浏览器的默认html 字体大小font-size=16px;
,如果我们不设置,就会使用默认的,为了计算方便,我们也可以设置html 字体大小font-size=10px;
。
2. 媒体查询
什么是媒体查询?
媒体查询(Media Query)是CSS3新语法。使用 @media
查询,可以针对不同的媒体类型定义不同的样式,或者说可以针对不同的屏幕尺寸设置不同的样式,当你重置浏览器大小的过程中,页面也会根据浏览器的宽度和高度重新渲染页面,目前针对很多苹果手机、Android手机,平板等设备都用得到多媒体查询。
媒体查询语法
@media mediatype and | not | only (media feature) {
CSS-Code;
}
1. 用 @media开头,注意@符号
2. mediatype 媒体类型
3. 关键字 and not only
4. media feature 媒体特性必须有小括号包含
- mediatype 媒体类型
将不同的终端设备划分成不同的类型,称为媒体类型
- 关键字
关键字将媒体类型或多个媒体特性连接到一起做为媒体查询的条件。
- and:可以将多个媒体特性连接到一起,相当于“且”的意思。
- not:排除某个媒体类型,相当于“非”的意思,可以省略。
- only:指定某个特定的媒体类型,可以省略。
- 媒体特性
每种媒体类型都具体各自不同的特性,根据不同媒体类型的媒体特性设置不同的展示风格。我们暂且了解下面三个,注意他们要加小括号包含。
媒体查询案例:
Document
上面代码的第二档,我们只写 x>=540,没有写小于多少,为什么没问题呢?因为CSS的层叠性,后面的会覆盖前面的,具体请看。
- 媒体查询书写规则
为了防止混乱,媒体查询我们一般按照从小到大来写,这样代码更简洁。
媒体查询+rem实现元素动态大小变化
- rem单位是跟着html来走的,有了rem页面元素可以设置不同大小尺寸
- 媒体查询可以根据不同设备宽度来修改样式
- 媒体查询+rem 就可以实现不同设备宽度,实现页面元素大小的动态变化
Document
购物车
根据设备尺寸引入css文件
当样式比较繁多的时候,我们可以针对不同的媒体使用不同 stylesheets(样式表),原理就是直接在link中判断设备尺寸,然后引用不同的css文件。
语法规范:
示例:
/* 当屏幕尺寸大于等于320px,引入styleA.css */
3. Less 的基本使用
CSS弊端
- CSS 是一门非程序式语言,没有变量、函数、SCOPE(作用域)等概念。
- CSS 需要书写大量看似没有逻辑的代码,CSS 冗余度是比较高的。
- 不方便维护及扩展,不利于复用。
- CSS 没有很好的计算能力。
- 非前端开发工程师来讲,往往会因为缺少 CSS 编写经验而很难写出组织良好且易于维护的 CSS 代码项目。
Less介绍
- Less(LeanerStyle Sheets 的缩写)是一门 CSS扩展语言,也称为CSS预处理器。
- Less的出现解决了上面我们说的CSS的弊端。
- 作为 CSS的一种形式的扩展,它并没有减少CSS的功能,而是在现有的CSS语法上,为CSS加入程序式语言的特性。
- 它在CSS 的语法基础之上,引入了变量,Mixin(混入),运算以及函数等功能,大大简化了 CSS 的编写,并且降低了 CSS的维护成本,就像它的名称所说的那样,Less可以让我们用更少的代码做更多的事情。
Less中文网址:http://lesscss.cn/
常见的CSS预处理器:Less、Sass。
一句话:Less是一门 CSS 预处理语言,它扩展了CSS的动态特性。
Less安装
① 通过node.js在线安装Less
1. 安装nodejs,可选择版本(8.0),网址:
2. 检查是否安装成功,使用cmd命令(win10是window+r 打开运行输入cmd) ---输入“node –v”查看版本即可
3. 先切换到淘宝镜像源,使用cmd命令:npm config set registry https://registry.npm.taobao.org
4. 查看是否切换成功:npm config get registry
5. 通过nodejs在线安装Less,使用cmd命令“sudo npm install -g less”即可
6. 检查是否安装成功,使用cmd命令“ lessc -v ”查看版本即可
② VSCode安装 Easy LESS 插件
本质上,Less 包含一套自定义的语法及一个解析器,用户根据这些语法定义自己的样式规则,这些规则最终会通过解析器,编译生成对应的 CSS 文件,所以,我们需要把我们的 less文件,编译生成为css文件,这样我们的html页面才能使用。
Easy LESS 插件用来把less文件编译为css文件,安装插件后,重新加载 vscode,只要 command+s
保存一下Less文件,会自动生成CSS文件,然后我们再引入这个CSS文件就可以使用了。
Less语法
我们首先新建一个后缀名为 .less
的文件,在这个less文件里面书写less语句。
① Less 变量
变量是指没有固定的值,可以改变的。
@变量名:值;
- 必须有@为前缀
- 不能包含特殊字符
- 不能以数字开头
- 大小写敏感
/* 定义一个粉色的变量 */
@color: pink;
使用示例:
/* 定义一个粉色的变量 */
@color: pink;
/* 错误的变量名 @123color @color~@# */
/* 变量名区分大小写 @color 和 @Color 是两个不同的变量 */
/* 定义了一个字体为14像素的变量 */
@font14: 14px;
/* 使用变量 */
body {
background-color: @color;
}
div {
color: @color;
font-size: @font14;
}
a {
font-size: @font14;
}
② Less 嵌套
- less嵌套,子元素的样式直接写到父元素里面就好了。
- 如果有伪类、伪元素、交集选择器,我们内层选择器的前面需要加&。
- 解析的时候,如果内层选择器的前面没有&符号,则它被解析为父选择器的后代,如果有&符号,它就被解析为父元素自身。
/* less文件这样写 */
/* 父元素 */
.header {
width: 200px;
height: 200px;
background-color: pink;
/* 子元素的样式直接写到父元素里面就好了 */
a {
/* 如果内层选择器的前面没有&符号,则它被解析为父选择器的后代 */
color: red;
/* 如果有伪类选择器、伪元素选择器、交集选择器 我们内层选择器的前面需要加& */
/* 链接伪类选择器,解析成 a:hover */
&:hover {
color: blue;
}
/* 伪元素选择器,解析成 a::before */
&::before {
content: "";
}
/* 交集选择器,解析成 a.one,选择的是类名为.one的a标签 */
&.one {
color: blue;
}
}
}
/* 生成的CSS文件 */
.header {
width: 200px;
height: 200px;
background-color: pink;
}
.header a {
color: red;
}
.header a:hover {
color: blue;
}
.header a::before {
content: "";
}
.header a.one {
color: blue;
}
③ Less 运算
任何数字、颜色或者变量都可以参与运算,因为Less提供了加(+)、减(-)、乘(*)、除(/)算术运算。
/* Less文件这样写 */
@baseFont: 50px;
html {
font-size: @baseFont; /* 结果为50px */
}
@border: 5px + 5;
div {
width: 200px - 50; /* 结果为150px */
height: (200px + 50px ) * 2; /* 结果为500px */
border: @border solid red; /* 结果为10px */
background-color: #666 - #222; /* 结果为#444 */
}
img {
width: 82rem / @baseFont; /* 结果为1.64rem,单位以第一个为准 */
height: 82rem / @baseFont;
}
/* 生成的CSS文件 */
html {
font-size: 50px;
}
div {
width: 150px;
height: 500px;
border: 10px solid red;
background-color: #444444;
}
img {
width: 1.64rem;
height: 1.64rem;
}
注意:如果两个值之间只有一个值有单位,则运算结果就取该单位。如果是两个不同的单位的值之间的运算,运算结果的单位以第一个值的单位为准。
4. rem适配方案
为了让一些不能等比自适应的元素,达到当设备尺寸发生改变的时候,等比例适配当前设备的效果,我们使用媒体查询根据不同设备按比例设置html的字体大小,然后页面元素使用rem做尺寸单位,当html字体大小变化,元素尺寸也会发生变化,从而达到等比缩放适配的目的。
技术方案:
- flex + 媒体查询 + rem
- flex + flexible.js + rem
两种方案现在都存在,方案2更简单,现阶段大家无需了解里面的js代码。
方案1:flex + 媒体查询 + rem
1. 设计稿常见尺寸宽度:
一般情况下,我们以一套或两套效果图适应大部分的屏幕,放弃极端屏或对其优雅降级,牺牲一些效果,现在基本以iPhone6、7、8 的 375*667 为准。
2. 动态设置 html 标签 font-size 大小
假设设计稿是750px,假设我们把整个屏幕划分为15等份(划分标准不一可以是20份也可以是10等份),每一份作为html字体大小,这里就是50px,那么在320px设备的时候,字体大小为 320 / 15 就是21.33px,最后设置宽高的时候只需要使用 rem 单位的尺寸就可以实现屏幕适配。
3. 元素大小取值方法
- 屏幕宽度 / 划分的份数 就是 html 的 font-size 的大小。
- 页面元素的 rem值 = 页面元素值(px) / html 的 font-size 字体大小。
设计稿以750px屏幕作为基准,示例代码如下:
Document
苏宁首页地址:苏宁首页
- 技术选型
方案:我们采取单独制作移动页面方案
技术:flex + 媒体查询 + rem + less
设计图: 本设计图采用 750px 设计尺寸
- 搭建文件结构
- 设置视口标签以及引入初始化样式
- 设置公共common.less文件
① 新建common.less 设置好最常见的屏幕尺寸,利用媒体查询设置不同的html字体大小,因为除了首页其他页面也需要。
② 我们关心的尺寸有 320px、360px、375px、384px、400px、414px、424px、480px、540px、720px、750px。
③ 划分的份数我们定为 15 等份。
④ 因为我们pc端也可以打开我们苏宁移动端首页,我们默认html字体大小为 50px。
- 新建index.less文件
① 新建 index.less,这里面写首页的样式
② 将刚才设置好的 common.less 引入到 index.less 里面语法如下:
/* 在 index.less 中导入common.less 文件 */
@import “common”
③ 生成index.css 引入到 index.html 里面
- body样式
body {
min-width: 320px;
width:15rem;
margin: 0 auto;
line-height: 1.5;
font-family: Arial,Helvetica;
background: #F2F2F2;
}
代码地址:苏宁移动端(flex + 媒体查询 + rem)
方案2:flex + flexible.js + rem
flexible.js + rem 是简洁高效的rem适配方案。flexible.js是手机淘宝团队出的简洁高效移动端适配库,我们再也不需要写不同屏幕的媒体查询,flexible.js就是监听window的resize事件,然后重新设置html的字体大小,它把当前设备划分为10等份,但是不同设备下,比例还是一致的。我们要做的,就是要确定当前设备的html 文字大小,然后根据 html 文字大小计算 rem 值,比如当前设计稿是 750px,分成 10 份就是 750px/10=75px,里面页面元素rem值就是:页面元素的 px 值 / 75。
github地址:https://github.com/amfe/lib-flexible
- 技术选型
方案:我们采取单独制作移动页面方案
技术:flex + flexible.js + rem
设计图:本设计图采用 750px 设计尺寸
- 搭建相关文件夹结构
- 设置视口标签以及引入初始化样式还有js文件
我们页面需要引入这个js文件
/* 在 index.html 中 引入 flexible.js 这个文件 */
- body样式
body {
min-width: 320px;
max-width: 750px;
width: 10rem;
margin: 0 auto;
line-height: 1.5;
font-family: Arial, Helvetica;
background: #f2f2f2;
}
px转换rem插件:cssrem
因为cssrem中css自动转化为rem是参照默认的html字体大小16,所以我们重新设置html字体大小基准值。
- 打开设置
- 搜索cssroot,因为我们的设计稿是750px的,并且分成了10等份,所以字体设置为75
注意:因为flexible是默认将屏幕分为10等分,但是当屏幕大于750的时候希望不要再去重置html字体了,所以要自己通过媒体查询设置一下,并且要把权重提到最高。详细代码地址:苏宁移动端(flex + flexible.js + rem)
五. 移动端布局:响应式布局
1. 响应式开发
① 响应式开发原理
就是使用媒体查询针对不同宽度的设备进行布局和样式的设置,从而适配不同设备的目的。
设备的划分情况:
② 响应式布局容器
响应式需要一个父级做为布局容器,来配合子级元素来实现变化效果,原理就是在不同屏幕下,通过媒体查询来改变这个布局容器的大小,再改变里面子元素的排列方式和大小,从而实现不同屏幕下,看到不同的页面布局和样式变化。
父容器版心的尺寸划分:
- 超小屏幕(手机,小于 768px):设置宽度为 100%
- 小屏幕(平板,大于等于 768px):设置宽度为 750px
- 中等屏幕(桌面显示器,大于等于 992px):宽度设置为 970px
- 大屏幕(大桌面显示器,大于等于 1200px):宽度设置为 1170px
但是我们也可以根据实际情况自己定义划分。
③ 响应式导航栏案例
- 当我们屏幕大于等于768像素,我们给布局容器container宽度为750px,container里面包含8个小li盒子,每个盒子的宽度定为93.75px(750 / 8),高度为30px,浮动一行显示。
- 当我们屏幕缩放,宽度小于768像素的时候,container盒子宽度修改为100%宽度,此时里面的8个小li,宽度修改为33.33%,这样一行就只能显示3个小li,剩余下行显示。
代码如下:
Document
- 导航栏
- 导航栏
- 导航栏
- 导航栏
- 导航栏
- 导航栏
- 导航栏
- 导航栏
2. Bootstrap的介绍
① Bootstrap简介
Bootstrap 来自 Twitter,是一个基于HTML、CSS 和 JavaScript,用于快速开发 Web 应用程序和网站的前端框架。
中文网:http://www.bootcss.com/
官网:http://getbootstrap.com/
推荐网站:http://bootstrap.css88.com/
② Bootstrap优点
- 移动设备优先:自Bootstrap3 开始,框架包含了贯穿于整个库的移动设备优先的样式。
- 响应式设计:Bootstrap的响应式 CSS 能够自适应于台式机、平板、电脑和手机,Bootstrap的响应式是基于媒体查询实现的。
- 内置组件:Bootstrap提供了一套简洁、直观、强悍的内置组件。
- 浏览器支持:所有主流浏览器均支持Bootstrap。
- 容易上手:只要您具备 HTML 和 CSS 的基础知识,就可以开始学习Bootstrap。
③ bootstrap版本
3.x.x:目前使用最多,稳定,但是放弃了IE6-IE7,对 IE8 支持但是界面效果不好,偏向用于开发响应式布局移动设备优先的Web项目。
4.x.x:最新版,目前还不是很流行
④ bootstrap基本使用
在现阶段我们还没有接触js相关课程,所以我们只考虑使用它的样式库。控制权在框架本身,使用者要按照框架所规定的某种规范进行开发。
Bootstrap 使用四步曲:
- 创建文件夹结构
-
创建 html 骨架结构
阿里百秀 你好,世界!
-
必须引入相关样式文件
-
书写内容
直接拿 Bootstrap 预先定义好的样式来使用。
修改 Bootstrap 原来的样式,注意权重问题。
学好 Bootstrap 的关键在于知道它定义了哪些样式,以及这些样式能实现什么样的效果。
⑤ bootstrap布局容器
Bootstrap 需要为页面内容和栅格系统包裹一个 .container 或者 .container-fluid 容器,bootstrap预先定义好了两个有此用处的类。
.container类
- 响应式布局的容器 固定宽度
- 大屏 ( >=1200px) 宽度定为 1170px
- 中屏 ( >=992px) 宽度定为 970px
- 小屏 ( >=768px) 宽度定为 750px
- 超小屏 (100%)
使用这个类之后,再也不用我们写媒体查询的代码了,bootstrap会自动改变container容器的宽度,下面我们主要学习.container类。
.container-fluid类
- 流式布局容器 百分百宽度
- 占据全部视口(viewport)的容器
- 适合于单独做移动端开发
⑥ bootstrap栅格系统
1. 栅格系统简介
栅格系统英文为“grid systems”,也有人翻译为“网格系统”,它是指将页面布局划分为等宽的列,然后通过列数的定义来模块化页面布局。
Bootstrap提供了一套响应式、移动设备优先的流式栅格系统,随着屏幕或视口(viewport)尺寸的增加,系统会自动分为最多12列。
2. 栅格选项参数
栅格系统用于通过一系列的行(row)与列(column)的组合来创建页面布局,你的内容就可以放入这些创建好的布局中。
- 行(row)必须放到container布局容器里面,这个和table标签的row有点像。
- 我们实现列的平均划分,需要给列添加类前缀,xs:extra small,超小;sm:small,小;md:medium,中等;lg large,大。
- 每一列默认有左右15像素的 padding,如果不想要可以去掉。
- 可以同时为一列指定多个设备的类名,以便划分不同份数 例如 class="col-md-4 col-sm-6"。
- 列(column)大于 12,多余的“列(column)”所在的元素将被作为一个整体另起一行排列。
① 如果孩子的份数相加等于12,则孩子能占满整 container 的宽度
② 如果孩子的份数相加小于12,则占不满整个container 的宽度,会有空白
③ 如果孩子的份数相加大于12,则多于的那一列会另起一行显示
3. 列嵌套
栅格系统可以将内容再次嵌套,简单理解就是一个列内再分成若干份小列。
我们列嵌套最好加1个行 row 这样可以取消父元素的padding值,而且高度自动和父级一样高。
a
b
2
3
4. 列偏移 (.col-md-offset-*)
使用 .col-md-offset-*
类可以将列向右侧偏移。这些类实际是通过使用选择器为当前元素增加了左侧的边(margin)。
1
2
5. 列排序 (.col-md-push-*)、(.col-md-pull-*)
通过使用 .col-md-push-*
和 .col-md-pull-*
类就可以很容易的改变列(column)的顺序。
左侧
右侧
6. 隐藏和显示 (hidden-xs)、(visible-xs)
为了加快对移动设备友好的页面开发工作,利用媒体查询功能,并使用这些工具类可以方便的针对不同设备展示或隐藏页面内容。
与之相反的是,visible-xs、visible-sm、visible-md、visible-lg 是显示某个界面内容。
我会显示哦
2
4
Bootstrap 其他 按钮、表单、表格 请参考 Bootstrap 文档。
3. 阿里百秀案例制作
1. 技术选型
方案:我们采取响应式页面开发方案
技术:bootstrap框架
设计图:本设计图采用 1280px 设计尺寸
2. 页面布局分析
3. 屏幕划分分析
屏幕缩放发现,中屏幕和大屏幕布局是一致的,因此我们列定义为col-md-*
就可以了,md是大于等于970以上的。小屏幕和超小屏幕布局发生变化,因此我们需要为小屏幕根据需求改变布局。
4. 项目结构搭建
Bootstrap 使用四步曲:
- 创建文件夹结构
- 创建 html 骨架结构
- 引入相关样式文件
- 书写内容
5. container宽度修改
因为本效果图采取1280的宽度,而Bootstrap里面container宽度最大为1170px,因此我们需要手动改下container最大宽度,当宽度大于1280px的时候,把宽度设置为1280px。
/* 利用媒体查询修改 container宽度适合效果图宽度 */
@media (min-width: 1280px) {
.container {
width: 1280px;
}
}
阿里百秀案例代码地址:阿里百秀案例
总结:移动端web开发主流方案
-
移动端单独制作(主流)。移动端和 PC 端各一份代码,移动端布局方式如下:
① 百分比布局(京东移动端案例)
② flex 伸缩布局(携程网移动端案例)
③ flex+媒体查询+rem(苏宁移动端案例)
④ flex+flexible.js+rem(苏宁移动端案例) -
响应式页面兼容移动端。移动端和 PC 端共用一份代码,响应式的布局移动端和 PC 端会响应式变化从而适应不同的屏幕大小。
① 媒体查询
② bootstarp(阿里百秀案例、三星手机官网)
总结:从传统的百分比布局到flex布局,最后到 flex + 媒体查询 + rem,我们发现最终的方案就是 flex + 媒体查询 + rem,因为上面的 flexible.js
其实就是代替我们写了一些媒体查询的js代码。
补充:最近又出现了新的单位,vw和vh,分别代表视口宽度、视口高度,比如1vw = 1%的视口宽度。rem、vw和vh桌面端仅在IE9+支持,如果需要支持IE8,只能使用px,但是在移动端rem、vw和vh都支持的比较好,可以在生产使用。