移动端常见布局
移动端技术选型
移动端布局和以前我们学习的PC端有所区别
1. 单独制作移动端页面(主流)
- 流式布局(百分比布局)
- flex弹性布局(强烈推荐)
- less+rem+媒体查询布局
- 混合布局
2. 响应式页面兼容移动端(其次)
- 媒体查询
- bootstrap
一. 流式布局(百分比布局)
- 流式布局,就是百分比布局,也称非固定像素布局
- 通过盒子的宽度设置成百分比来根据屏幕的宽度来进行伸缩,不受固定像素的限制,内容向两侧填充
- 流式布局方式是移动web开发使用的比较常见的布局方式
- max-width 最大宽度 (max-height 最大宽度)
- min-width 最小宽度 (min-height 最小高度)
案例:京东移动端首页
1. 技术选型
方案:采取单独制作移动页面方案
技术:布局采取流式布局
5. 二倍精灵图做法
- 在firework里面把精灵图等比例缩放为原来的一半
- 之后根据大小测量坐标
- 注意代码里面background-size也要写:精灵图原来宽度的一半
6. 图片格式
DPG图片压缩格式
京东自主研发推出DPG图片压缩技术,可直接节省用户近50%的浏览流量,能兼容jpeg,全部浏览器支持,压缩后图片和webp的清晰度对比没有差距
webp图片格式
谷歌开发的一种为加快图片加载速度的图片格式,图片压缩体积大约只有JPEG的2/3,节省大量服务器宽带资源和数据空间
二. flex弹性布局
1. 传统布局和flex布局
传统布局:
- 兼容性好
- 布局繁琐
- 局限性,不能再移动端很好的布局
flex布局:
- 操作方便,布局极为简单,移动端应用广泛
- PC端浏览器支持情况较差
- IE11或更低版本,不支持或仅部分支持
建议:
- 如果是PC端页面布局,我们还是传统布局
- 如果是移动端或者不考虑兼容性问题的PC端页面布局,我们还是使用flex弹性布局
2.flex布局原理
flex是flexible Box的缩写,意为“弹性布局”,用来为盒状模型提供最大的灵活性,任何一个容器都可以指定为flex布局。
- 当我们将父盒子设为flex布局以后,子元素的float、clear和vertical-align属性将失效。
- 伸缩布局=弹性布局=伸缩盒布局=弹性盒布局=flex布局
采用Flex布局的元素,称为Flex容器(flex container),简称“容器”。它的所有子元素自动成为容器成员,称为Flex项目(flex item),简称“项目”。
- 在01-flex布局体验.html中div就是flex父容器
- 在01-flex布局体验.html中span就是子容器flex项目
- 子容器可以横向排列也可以纵向排列
总结flex布局原理:就是通过给父盒子添加flex属性,来控制盒子的位置和排列方式
3.常见父项属性
- flex-direction:设置主轴的方向
- justify-content:设置主轴上的子元素排列方式
- flex-wrap:设置子元素是否换行
- align-content:设置侧轴上的子元素的排列方式(多行)
- align-items:设置侧轴上的子元素排列方式(单行)
- flex-flow:复合属性,相当于同时设置了flex-direction和flex-wrap
-
flex-direction 设置主轴的方向
主轴和侧轴
在flex布局中,是分为主轴和侧轴两个方向,同样的叫法有:行和列,x轴和y轴
- 默认主轴方向就是x轴方向,水平向右
- 默认侧轴方向就是y轴方向,垂直向下
属性值
flex-direction属性决定主轴的变化方向(即项目的排列方向)
注意:主轴和侧轴是会变化的,就看flex-direction设置谁为主轴,剩下的就是侧轴。而我们的子元素是跟着主轴来排列的
属性值 说明 row 默认值从左到右 row-reverse 从右到左 column 从上到下 column-reverse 从下到上 -
justify-content 设置主轴上的子元素排列方式
justify-content属性定义了项目在主轴上的对齐方式
注意:使用这个属性之前一定要确定好主轴是哪个
属性值 说明 flex-start 默认值 从头开始 如果主轴是x轴,则从左到右 flex-end 从尾部开始排列 center 在主轴居中对齐(如果主轴是x轴则水平居中) space-around 平分剩余空间 space-between 先两边贴边 再平分剩余空间(重要) -
flex-wrap 设置子元素是否换行
默认情况下,项目都排在一条直线(又称"轴线")上。flex-wrap属性定义,flex布局中默认是不换行的。
属性值 说明 nowrap 默认值,不换行 wrap 换行 -
align-items 设置侧轴上的子元素排列方式(单行)
该属性是控制子项在侧轴(默认是y轴)上的排列方式 在子项为单项(单行)的时候使用
属性值 说明 flex-start 从上到下 flex-end 从下到上 center 挤在一起居中(垂直居中) stretch 拉伸(默认值) -
align-content 设置侧轴上的子元素的排列方式(多行)
设置子项在侧轴上的排列方式,并且只能用于子项出现换行的情况(多行),在单行下是没有效果的。
属性值 说明 flex-start 默认值在侧轴的头部开始排列 flex-end 在侧轴的尾部开始排列 center 在侧轴中间显示 sapce-around 子项在侧轴平分剩余空间 space-between 子项在侧轴先分布在两头,再平分剩余空间 stretch 设置子项元素高度平分父元素高度 -
align-content和align-items区别
- align-items适用于单行情况下,只有上对齐、下对齐、居中和拉伸
- align-content适应于换行(多行)的情况下(单行情况下无效),可以设置上对齐、下对齐、居中、拉伸以及平均分配剩余空间等属性值。
- 总结就是单行找align-items 多行找align-content
-
flex-flow
flex-flow属性是flex-direction和flex-wrap属性的复合属性
flex-flow:row wrap;
4. flex布局子项常见属性
- flex子项目占的份数
- align-self控制子项自己在侧轴的排列方式
- order属性定义子项的排列顺序(前后顺序)
4.1 flex属性
flex属性定义子项目分配剩余空间,用flex来表示占多少份数
.item {
flex: <number>; /* default 0 */
}
4.2 align-self控制子项自己在侧轴上的排列方式
align-self属性允许单个项目有与其他项目不一样的对齐方式,可覆盖align-items属性。
默认值为auto,表示继承父元素的align-items属性,如果没有父元素,则等同于stretch.
span:nth-child(2) {
/*设置自己在侧轴上的排列方式*/
align-self: flex-end;
}
4.3 order属性定义项目的排列顺序
数值越小,排列越靠前,默认是0。
注意:和z-index不一样。
案例:携程网移动端首页
访问地址:m.ctrip.com
1. 技术选型
方案:我们采取单独制作移动页面方案
技术:布局采取flex布局
常见flex布局思路
默认主轴是x轴–>把主轴设为y轴–>把侧轴设为居中对齐
flex布局中不会出现外边距合并的问题
背景线性渐变
语法1:
background: linear-gradient(起始方向,颜色1,颜色2,...);
background: -webkit-linear-gradient(left, red, blue);
background: -webkit-linear-gradient(left top, red, blue);
背景渐变必须添加浏览器私有前缀
起始方向可以是:方位名词 或者 度数,如果省略默认就是top
三. less+rem+媒体查询布局
1. rem基础
rem单位
rem(root em)是一个相对单位,类似于em,em是父元素字体大小。
不同的是rem的基准是相对于html元素的字体大小。
比如,根元素(html)设置font-size=12px;非根元素设置width:2rem;则换成px表示就是24px。
2. 媒体查询
2.1 什么是媒体查询
媒体查询(Media Query)是CSS3新语法。
- 使用@media查询,可以针对不同的媒体类型定义不同的样式
- @media可以针对不同的屏幕尺寸设置不同的样式
- 当你重置浏览器大小的过程中,页面也会根据浏览器的宽度和高度重新渲染页面
- 目前针对很多苹果手机、Android手机,平板等设备都用得到多媒体查询
2.2 语法规范
@media mediatype and|not|only (media feature) {
CSS-Code;
}
- 用@media开头 注意@符号
- mediatype媒体类型
- 关键字 and not only
- media feature媒体特性 必须有小括号包含
-
mediatype查询类型
将不同的终端设备划分成不同的类型,称为媒体类型
值 解释说明 all 用于所有设备 print 用于打印机和打印预览 scree 用于电脑屏幕,平板电脑,智能手机等 -
关键字
关键字将媒体类型或多个媒体特性连接到一起做为媒体查询的条件
- and:可以将多个媒体特性连接到一起,相当于“且”的意思。
- not:排除某个媒体类型,相当于“非”的意思,可以省略
- only:指定某个特定的媒体类型,可以省略。
-
媒体特性
每种媒体类型都具有各自不同的特性,根据不同媒体类型的媒体特性设置不同的展示风格。我们暂且了解三个。注意他们要加小括号包含
值 解释说明 width 定义输出设备中页面可见区域的宽度 min-width 定义输出设备中页面最小可见区域宽度 max-width 定义输出设备中页面最大可见区域宽度 注意:为了防止混乱,媒体查询我们要按照从小到大或者从大到小的顺序来写,但是我们最喜欢的还是从小到大来写,这样代码更简洁
2.3 媒体查询+rem实现元素动态大小变化
rem单位是个跟着html来走的,有了rem页面元素可以设置不同大小尺寸
媒体查询可以根据不同设备宽度来修改样式
媒体查询+rem就可以实现不同设备宽度,实现页面元素大小的动态变化
2.4 引入资源(理解)
当样式比较繁多的时候,我们可以针对不同的媒体使用不同stylesheets(样式表)。
原理,就是直接在link中判断设备的尺寸,然后引用不同的css文件。
-
语法规范
<link rel="stylesheet" media="mediatype and|not|only (media feature)" href="mystylesheet.css">
3. Less基础
3.1 维护css的弊端
CSS是一门非程序式语言,没有变量、函数、SCOPE(作用域)等概念。
- CSS需要书写大量看似没有逻辑的代码,CSS冗余度是比较高的。
- 不方便维护及发展,不利于复用。
- CSS没有很好的计算能力。
- 非前端开发工程师来讲,往往会因为缺少CSS编写经验而很难写出组织良好且易于维护的CSS代码项目。
3.2 Less介绍
Less(Leaner Style Sheets的缩写)是一门CSS扩展语言,也成为CSS预处理器。
做为CSS的一种形式的扩展,它并没有减少CSS的功能,而是在现有的CSS语法上,为CSS加入程序式语言的特性。
它在CSS的语法基础之上,引入了变量,Mixin(混入),运算以及函数等功能,大大简化了CSS的编写,并且降低了CSS的维护成本。
Less中文网址:http://lesscss.cn/
常见的CSS预处理器:Sass、Less、Stylus
Less是一门CSS预处理语言,它扩展了CSS的动态特性。
3.3 Less使用
我们首先新建一个后缀名为less的文件,在这个less文件里面书写less语句。
-
Less变量
变量是指没有固定的值,可以改变的。因为我们CSS中的一些颜色和数值等经常使用。
@变量名:值;
1.变量命名规范
- 必须有@为前缀
- 不能包含特殊字符
- 不能以数字开头
- 大小写敏感
-
Less编译
本质上,Less包含一套自定义的语法以及一个解析器,用户根据这些语法定义自己的样式规则,这些规则最终会通过解析器,编译生成对于的CSS文件。
所以,我们需要把我们的less文件,编译生成为css文件,这样我们的html页面才能使用。
vscode Less插件
Easy LESS插件用来把less文件编译为css文件,安装完插件,重新加载下vscode。只要保存一下Less文件,会自动生成CSS文件。
-
Less嵌套
经常用到选择器的嵌套
#header .logo { width: 300px; }
Less嵌套写法
#header { .logo { width: 300px; } }
如果遇见(交集|伪类|伪元素选择器)
- 内层选择器的前面没有&符号,则它被解析为父选择器的后代;
- 如果有&符号,它就被解析为父元素自身或父元素的伪类。
a:hover { color:red; }
Less嵌套写法
a { &:hover { color:red; } }
-
Less运算
任何数字、颜色或者变量都可以参与运算。就是Less提供了加(+)、减(-)、乘(*)、除(/)算术运算。
/*Less 里面写*/
@width: 10px +5;
div {
border: @width solid red;
}
/*生成的css*/
div {
border: 15px solid red;
}
/*Less 甚至可以这么写*/
width: (@width + 5) * 2;
注意:
- 乘号(*)和除号(/)的写法
- 运算符中间左右有个空格隔开1px+5
- 对于两个不同的单位的值之间的运算,运算结果的值取第一个值的单位
- 如果两个值之间只有一个值有单位,则运算结果就取该单位
4. rem适配方案
4.1 rem适配
-
我们适配的目标是什么?
让一些不能等比自适应的元素,达到当设备尺寸发生改变的时候,等比列适配当前设备。
-
怎么去达到这个目标的?
使用媒体查询根据不同的设备按比例设置html的字体大小,然后页面元素使用rem做尺寸单位,当html字体大小变化,元素尺寸也会发生变化,从而达到等比列缩放的适配。
-
在实际的开发当中使用?
- 按照设计稿与设备宽度的比例,动态计算并设置html根标签的font-size大小;(媒体查询)
- CSS中,设计稿元素的宽、高、相对位置等取值,按照同等比例换算为rem为单位的值;
4.2 rem适配方案技术使用(市场主流)
技术方案1
- less
- 媒体查询
- rem
技术方案2
- flexible.js
- rem
总结:
- 两种方案现在都存在
- 方案2更简单,现阶段无需了解里面的js代码
4.3 rem实际开发适配方案1
rem+媒体查询+less技术
1.设计稿常见尺寸宽度
设备 | 常见宽度 |
---|---|
iphone 4.5 | 640px |
iphone 6.7.8 | 750px |
Android | 常见320px、360px、375px、384px、400px、414px、500px、720px大部分4.7~5寸的安卓设备为720px |
一般情况,我们以一套或两套效果图适应大部分屏幕,放弃极端或对其优雅降级,牺牲一些效果。
现在基本以750为准。
2.动态设置html标签font-size大小
- 假设设计稿是750px
- 假设我们把整个屏幕分为15等份(划分标准不一可以是20份也可以是10份)
- 每一份作为html字体大小,这里就是50px
- 那么在320px设备的时候,字体大小为320/15就是21.33px
- 用我们页面元素的大小 除以不同的html字体大小会发现他们比例还是相同的
- 比如我们以750为标准设计稿
- 一个100*100像素的页面元素在 750屏幕下,就是100/50转换为rem 是 2rem * 2rem 比例是1比1
- 320屏幕下,html字体大小为21.33 则2rem=42.66px 此时宽和高都是 42.66 但是宽和高的比例还是1比1
- 但是已经能实现不同屏幕下 页面元素盒子等比例缩放的效果
3.元素大小取值方法
- 最后的公式:页面元素的rem值=页面元素值 (px) / (屏幕宽度/划分的份数)【例如:rem=100px / (750px/15份)】
- 屏幕宽度/划分的份数 就是html font-size的大小
- 或者:页面元素的rem值=页面元素(px)/ html font-size 字体大小
案例:苏宁网移动端首页
访问网址:m.suning.com
1. 技术选型
方案:我们采取单独制作移动页面方案
技术:布局采取rem适配布局(less+rem+媒体查询)
设计图:本设计图采用750px设计尺寸
步骤:
-
设置视口标签以及引入初始化样式
<meta name="viewport" content="width=device-width, initial-scale=1.0,user-scalable=no, maximum-scale=1.0, minimum-scale=1.0"> <link rel="stylesheet" href="css/normalize.css">
-
设置公共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里面
-
4.4 使用适配方案2制作苏宁移动端首页
-
简介高效的rem适配方案flexible.js
手机淘宝团队出的简洁高效 移动适配库
不在需要写不同屏幕的媒体查询,因为里面js做了处理
它的原理是把当前设备划分为10等份,但是不同设备下,比例还是一致的。我们要做的就是确定好当前设备的html文字大小就可以了
比如当前设计稿是750px,我们只需要把html文字大小设置为75px(750px/10)即可,里面页面元素rem值:页面元素的px值/75px
剩余的,让flexible.js来去算
github地址:https://github.com/amfe/lib-flexible
-
技术选型
方案:我们采取单独制作移动页面方案
技术:布局采取rem适配布局2(flexible.js + rem)
设计图:本设计图采用750px设计尺寸
-
设置视口标签以及引入初始化样式还有js文件
引入js文件
在index.html中引入flexible.js这个文件 <script src="js/flexible.js"></script>