移动端常见布局

移动端常见布局

移动端技术选型

移动端布局和以前我们学习的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或更低版本,不支持或仅部分支持

建议:

  1. 如果是PC端页面布局,我们还是传统布局
  2. 如果是移动端或者不考虑兼容性问题的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
  1. flex-direction 设置主轴的方向

    主轴和侧轴

    在flex布局中,是分为主轴和侧轴两个方向,同样的叫法有:行和列,x轴和y轴

    • 默认主轴方向就是x轴方向,水平向右
    • 默认侧轴方向就是y轴方向,垂直向下

    属性值

    flex-direction属性决定主轴的变化方向(即项目的排列方向)

    注意:主轴和侧轴是会变化的,就看flex-direction设置谁为主轴,剩下的就是侧轴。而我们的子元素是跟着主轴来排列的

    属性值 说明
    row 默认值从左到右
    row-reverse 从右到左
    column 从上到下
    column-reverse 从下到上
  2. justify-content 设置主轴上的子元素排列方式

    justify-content属性定义了项目在主轴上的对齐方式

    注意:使用这个属性之前一定要确定好主轴是哪个

    属性值 说明
    flex-start 默认值 从头开始 如果主轴是x轴,则从左到右
    flex-end 从尾部开始排列
    center 在主轴居中对齐(如果主轴是x轴则水平居中)
    space-around 平分剩余空间
    space-between 先两边贴边 再平分剩余空间(重要)
  3. flex-wrap 设置子元素是否换行

    默认情况下,项目都排在一条直线(又称"轴线")上。flex-wrap属性定义,flex布局中默认是不换行的。

    属性值 说明
    nowrap 默认值,不换行
    wrap 换行
  4. align-items 设置侧轴上的子元素排列方式(单行)

    该属性是控制子项在侧轴(默认是y轴)上的排列方式 在子项为单项(单行)的时候使用

    属性值 说明
    flex-start 从上到下
    flex-end 从下到上
    center 挤在一起居中(垂直居中)
    stretch 拉伸(默认值)
  5. align-content 设置侧轴上的子元素的排列方式(多行)

    设置子项在侧轴上的排列方式,并且只能用于子项出现换行的情况(多行),在单行下是没有效果的。

    属性值 说明
    flex-start 默认值在侧轴的头部开始排列
    flex-end 在侧轴的尾部开始排列
    center 在侧轴中间显示
    sapce-around 子项在侧轴平分剩余空间
    space-between 子项在侧轴先分布在两头,再平分剩余空间
    stretch 设置子项元素高度平分父元素高度
  6. align-content和align-items区别
  • align-items适用于单行情况下,只有上对齐、下对齐、居中和拉伸
  • align-content适应于换行(多行)的情况下(单行情况下无效),可以设置上对齐、下对齐、居中、拉伸以及平均分配剩余空间等属性值。
  • 总结就是单行找align-items 多行找align-content
  1. 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媒体特性 必须有小括号包含
  1. mediatype查询类型

    将不同的终端设备划分成不同的类型,称为媒体类型

    解释说明
    all 用于所有设备
    print 用于打印机和打印预览
    scree 用于电脑屏幕,平板电脑,智能手机等
  2. 关键字

    关键字将媒体类型或多个媒体特性连接到一起做为媒体查询的条件

    • and:可以将多个媒体特性连接到一起,相当于“且”的意思。
    • not:排除某个媒体类型,相当于“非”的意思,可以省略
    • only:指定某个特定的媒体类型,可以省略。
  3. 媒体特性

    每种媒体类型都具有各自不同的特性,根据不同媒体类型的媒体特性设置不同的展示风格。我们暂且了解三个。注意他们要加小括号包含

    解释说明
    width 定义输出设备中页面可见区域的宽度
    min-width 定义输出设备中页面最小可见区域宽度
    max-width 定义输出设备中页面最大可见区域宽度

    注意:为了防止混乱,媒体查询我们要按照从小到大或者从大到小的顺序来写,但是我们最喜欢的还是从小到大来写,这样代码更简洁

2.3 媒体查询+rem实现元素动态大小变化

rem单位是个跟着html来走的,有了rem页面元素可以设置不同大小尺寸

媒体查询可以根据不同设备宽度来修改样式

媒体查询+rem就可以实现不同设备宽度,实现页面元素大小的动态变化

2.4 引入资源(理解)

当样式比较繁多的时候,我们可以针对不同的媒体使用不同stylesheets(样式表)。

原理,就是直接在link中判断设备的尺寸,然后引用不同的css文件。

  1. 语法规范

    <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适配
  1. 我们适配的目标是什么?

    让一些不能等比自适应的元素,达到当设备尺寸发生改变的时候,等比列适配当前设备。

  2. 怎么去达到这个目标的?

    使用媒体查询根据不同的设备按比例设置html的字体大小,然后页面元素使用rem做尺寸单位,当html字体大小变化,元素尺寸也会发生变化,从而达到等比列缩放的适配。

  3. 在实际的开发当中使用?

    • 按照设计稿与设备宽度的比例,动态计算并设置html根标签的font-size大小;(媒体查询)
    • CSS中,设计稿元素的宽、高、相对位置等取值,按照同等比例换算为rem为单位的值;
4.2 rem适配方案技术使用(市场主流)

技术方案1

  • less
  • 媒体查询
  • rem

技术方案2

  • flexible.js
  • rem

总结:

  1. 两种方案现在都存在
  2. 方案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大小

  1. 假设设计稿是750px
  2. 假设我们把整个屏幕分为15等份(划分标准不一可以是20份也可以是10份)
  3. 每一份作为html字体大小,这里就是50px
  4. 那么在320px设备的时候,字体大小为320/15就是21.33px
  5. 用我们页面元素的大小 除以不同的html字体大小会发现他们比例还是相同的
  6. 比如我们以750为标准设计稿
  7. 一个100*100像素的页面元素在 750屏幕下,就是100/50转换为rem 是 2rem * 2rem 比例是1比1
  8. 320屏幕下,html字体大小为21.33 则2rem=42.66px 此时宽和高都是 42.66 但是宽和高的比例还是1比1
  9. 但是已经能实现不同屏幕下 页面元素盒子等比例缩放的效果

3.元素大小取值方法

  1. 最后的公式:页面元素的rem值=页面元素值 (px) / (屏幕宽度/划分的份数)【例如:rem=100px / (750px/15份)】
  2. 屏幕宽度/划分的份数 就是html font-size的大小
  3. 或者:页面元素的rem值=页面元素(px)/ html font-size 字体大小

案例:苏宁网移动端首页

访问网址:m.suning.com

1. 技术选型

方案:我们采取单独制作移动页面方案

技术:布局采取rem适配布局(less+rem+媒体查询)

设计图:本设计图采用750px设计尺寸

步骤:

  1. 设置视口标签以及引入初始化样式

    <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">
    
  2. 设置公共common.less文件

    • 新建common.less 设置好最常见的屏幕尺寸,利用媒体查询设置不同的html字体大小,因为除了首页也需要
    • 我们关心的尺寸有320px、360px、375px、384px、400px、414px、424px、480px、540px、720px、750px
    • 划分的份数我们定为15等份
    • 因为我们pc端也可以打开我们苏宁移动端首页,我们默认html字体大小为50px,注意这句话写到最上面
  3. 新建index.less文件

    • 新建index.less 这里面写首页的样式

    • 将刚才设置好的common.less引入到index.less里面 语法如下:

      //在 index.less 中导入  common.less文件
      @import "common"
      
    • 生成index.css引入到index.html里面

4.4 使用适配方案2制作苏宁移动端首页
  1. 简介高效的rem适配方案flexible.js

    手机淘宝团队出的简洁高效 移动适配库

    不在需要写不同屏幕的媒体查询,因为里面js做了处理

    它的原理是把当前设备划分为10等份,但是不同设备下,比例还是一致的。我们要做的就是确定好当前设备的html文字大小就可以了

    比如当前设计稿是750px,我们只需要把html文字大小设置为75px(750px/10)即可,里面页面元素rem值:页面元素的px值/75px

    剩余的,让flexible.js来去算

    github地址:https://github.com/amfe/lib-flexible

  2. 技术选型

    方案:我们采取单独制作移动页面方案

    技术:布局采取rem适配布局2(flexible.js + rem)

    设计图:本设计图采用750px设计尺寸

  3. 设置视口标签以及引入初始化样式还有js文件

    引入js文件

    在index.html中引入flexible.js这个文件
    <script src="js/flexible.js"></script>
    
上一篇:移动布局第五天 rem布局


下一篇:动态设置rem