移动端常见布局
移动端技术选型
1.单独制作移动端页面(主流)
流式布局(百分比布局)flex弹性布局(强烈推荐)less+rem+媒体查询布局混合布局
2.响应式页面兼容移动端(其次)
媒体查询bootstrap
一、流式布局(百分比布局)
流式布局,就是百分比布局,也称非固定像素布局
通过盒子的宽度设置成百分比来根据屏幕的宽度来进行伸缩,不受固定像素的限制,内容向两侧填充
流式布局方式是移动Web开发使用的比较常见的布局方式
max-width(max-height)最大宽度
min-width(min-height)最小宽度
二倍精灵图做法
1.在PS中把精灵图等比例缩放为原来的一半
2.之后根据大小测量坐标
3.注意代码里面background-size也要写:精灵图原来宽度的一半
二、flex布局体验
传统布局与flex布局
【传统布局】
兼容性好布局繁杂局限性,不能在移动端很好地布局
【flex布局】
操作方便,布局极为简单,移动端应用很广泛PC端浏览器支持情况较差IE11 或更低版本,不支持或仅部分支持
建议:
如果是PC端页面布局,我们还是建议使用传统布局如果是移动端或者不考虑兼容性问题的PC端页面布局,我们还是使用flex弹性布局
布局原理
flex是flexible Box的缩写,意为“弹性组件”,为盒状模型提供最大的数量,任何一个容器都可以为flex布局指定。
当我们为父盒子设为 flex 布局以后,子元素的float(浮动)、clear(清除)和vertical-align(垂直对齐)属性将失效。弹性布局=弹性布局=弹性组件布局=弹性组件布局=flex布局
采用flex布局的元素,称为flex容器(flex container),简称“容器”。
它的所有子元素自动成为容器成员 ,称为Flex项目(flex item),简称“项目”。
上面的体验中div就是flex父容器上面的体验中span就是子容器flex项目子容器可以横向排列也可以纵向排列
【总结flex布局原理】
就是通过给父盒子添加flex属性,来控制子盒子的位置和排列方式。
flex组件父项常见属性
常见父项属性
以下由6个属性是对父元素设置的
flex-direction:设置主轴的方向justify-content:设置主轴上的子元素排列方式flex-wrap:设置子元素是否换行align-content:设置侧轴上的子元素的排列方式(多行)align-items:设置侧轴上的子元素排列方式(单行)flex-flow:复合属性,相当于同时设置了 flex-direction 和 flex-wrap
1、flex-direction设置主轴的方向 ¤
(1)主轴与侧轴
在flex布局中,是分为主轴和侧轴两个方向,同样的叫法有:行和列、x轴和y轴
默认主轴方向就是x轴方向,水平向右默认侧轴方向就是y轴方向,水平方下
(2)属性值
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 属性定义,flex 布局中默认是不换行的。
属性值说明nowrap不换行(默认值)wrap换行
4、 align-items设置侧轴上的子元素排列方式(单行)¤
该属性是控制子项在侧轴(默认是y轴)上的排列方式,在子项为单项(单行)的时候使用。
属性值说明flex-start从上到下flex-end从下到上center挤在一起居中(垂直居中)stretch拉伸(默认值)注:前提是子盒子没有指定的高度,否则没有效果!
5、align-content 设置侧轴上的子元素的排列方式(多行)
设置子项在侧轴上的排列方式并且只能用于子项出现 换行 的情况 (多行) ,在单行下是没有效果的。
属性值说明flex-start在侧轴的头部开始排列(默认值)flex-end在侧轴的尾部开始排列center在侧轴中间显示space-around子项在侧轴平分剩余空间space-between子项在侧轴先分布在两头,再平分剩余空间stretch设置子元素高度平分父元素高度
align-content和align-items的区别
align-items 适用于单行情况下,只有上对齐、下对齐、居中和拉伸align-content 适应于换行(多行)的情况下(单行情况下无效),可以设置上对齐、下对齐、居中、拉伸以及平分剩余空间等属性。总结就是单行找 align-items 多行找 align-content
6、flex-flow 属性
flex-flow 属性是 flex-direction 和 flex-wrap 属性的复合属性
flex-flow: row wrap;
flex-direction:设置主轴的方向justify-content:设置主轴上的子元素排列方式flex-wrap:设置子元素是否换行align-content:设置侧轴上的子元素的排列方式(多行)align-items:设置侧轴上的子元素排列方式(单行)flex-flow:复合属性,同时设置了 flex-direction 和 flex-wrap
flex布局子项常见属性
flex 子项目占的份数align-self 控制子项自己在侧轴的排列方式order属性定义子项的排列顺序(先后顺序)
1、flex属性 ¤
flex 属性定义子项目分配剩余空间,用 flex 来表示占多少份数。
. 项目{
flex:
}
2、align-self控制子项自己在侧轴上的排列方式
align-self 属性允许单个项目有与其他项目不一样的对齐方式,可覆盖align-items属性。
默认值为auto,表示继承父元素的align-items属性,如果没有父元素,则等同于stretch。
span:nth-child(2) {
/* 设置自己在侧轴上的排列方式 */
align-self: flex-end;
}
3、order属性定义项目的排列顺序
数值越小,排列越靠前,默认为0。
注意:和 z-index 不一样。
. 项目{
order:<编号>; /* 默认是0 */
}
三、rem适配布局
【思考】
页面布局能否随着屏幕大小变化而变化?流式布局和flex布局主要针对于宽度布局,那高度如何设置?怎么样让屏幕发生变化的时候元素高度和宽度等比例缩放?
1、rem 单位
rem(root em)是一个相对单位,类似于em,em 是父元素字体大小。
不同的是rem 的基准是相对于 html 元素的字体大小。
例如,根元素(html)设置font-size=12px;非根元素设置width: 2rem;则换成 px 表示就是24px。
页面只有一个html,可以很好地控制整个页面的元素大小.(即:达到统一控制字体大小的效果!)
注意:rem 控制的字体大小,可以控制其他元素的大小。
/* 根 html 为 12px */
html {
font-size : 12 px ;
}
/*此时div的大小字体就是24px */
div {
font-size : 2 rem;
}
注:虽然使用 rem 之后实现了字体大小的统一控制,但仍然无法根据图片大小自动适配,所以我们还需要学习媒体查询。
2、媒体查询
媒体查询(Media Query)是 CSS3 新语法。
使用@media 查询,可以对不同的媒体类型定义不同的样式@media 可以针对不同的屏幕尺寸设置不同的样式当你重置浏览器大小的过程中,页面也会根据浏览器的宽度和高度重新渲染页面目前针对很多苹果手机、Android手机、平板等设备都用得到多媒体查询
@media mediatype and|not|only (media feature) { CSS-Code;}
用@media 开头 注意@符号mediatype 媒体类型关键字 and not onlymedia feature 媒体特性 必须有小括号包含
① mediatype 查询类型
将不同的终端设备划分成不同的类型,不同的媒体类型
值解释说明all用于所有设备print用于打印机和打印预览scree用于电脑屏幕、平板电脑、智能手机等
② 关键字
关键字将媒体类型或多种媒体特性连接到一起做为媒体查询的条件。
and:可以将多个媒体特性连接到一起,相当于“且”的意思。not:排除某个媒体类型,相当于“非”的意思,可以省略。only:指定某个特定的媒体类型,可以省略。
③ 媒体特性
每种媒体类型都有各自不同的特性,根据不同媒体类型的媒体特性设置不同的展示风格。我们暂且了解三个。注意他们要加小括号包含
值解释说明width定义输出设备中页面可见区域的宽度min-width定义输出设备中页面最小可见区域的宽度max-width定义输出设备中页面最大可见区域的宽度
3、媒体查询+rem实现元素动态大小变化
rem 单位是跟着html来走的,有了rem页面元素可以设置不同大小尺寸。
媒体查询可以根据不同的设备宽度来修改样式。
媒体查询 + rem 就可以实现不同的设备宽度,实现页面元素大小的动态变化。
4、引入资源(理解)
当样式比较繁多的时候,我们可以针对不同的媒体使用不同的样式表(stylesheets)。
比如:从PC端样式变移动端样式时,最好单独写样式表
原理,就是直接在link中判断设备的尺寸,然后引用不同的 CSS 文件。
(1)语法规范
< link rel =" stylesheet " media =" mediatype and|not|only (media feature) " href =" mystylesheet.css " >
(2)实例
< link rel =" stylesheet " href =" styleA.css " media =" screen and (min-width: 400px) " >
CSS弊端及Less的应用
1、维护CSS的弊端
CSS 是一门非程序式语言,没有变量、函数、SCOPE(作用域)等概念。
CSS 需要书写大量看似没有逻辑的代码,CSS冗余度是比较高的。不方便维护及扩展,不利于复用。CSS没有很好的计算能力非前端开发工程师来讲,往往会因为缺少 CSS 编写经验而很难写出组织良好且易于维护的 CSS 代码项目。
2、Less介绍
Less(Leaner Style Sheets 的缩写)是一门 CSS 扩展语言,也就是 CSS 预处理器。
做为 CSS 的一种形式的扩展,它并没有减少 CSS 的功能,而是在已有的 CSS 语法上,为 CSS 加入了程序式语言的特性。
它在 CSS 的语法基础之上,引入了变量,Mixin(混入),运算以及函数等功能,大大简化了CSS的编写,并且降低了 CSS 的维护成本,就像它的名称所说的那样,Less 可以让我们用更少的代码做更多的事情。
Less中文网址:Less 中文网http://lesscss.cn/
常见的CSS预处理器:Sass、Less、Stylus
一句话:Less 是一门 CSS 预处理语言,它扩展了 CSS 的动态特性。
3、Less使用
我们首先新建一个后缀名为less的文件,在这个less文件里面书写less语句
less变量less编译less嵌套less运算
4、Less变量
变量是指没有固定值,可以改变的。因为我们 CSS 中的一些颜色和数值等经常使用。
@变量名: 值;
① 变量命名规范
必须有@为前缀不能包含特殊的字符不能以数字开头大小写敏感
@color: pink;
② 变量使用规范
//直接使用
body {
color : @color ;
}
div {
color:@color ;
}
5、Less编译
本质上,less包含自定义的语法及一个解析器,用户根据这些语法定义自己的样式规则,这些规则最终会通过解析器,编译生成对应的 CSS 文件。
所以,我们需要把我们的less文件,编译生成 CSS 文件,这样我们的HTML页面才能使用。
6、Less编码
① Less嵌套 子元素的样式直接写到父元素里面就好了
@color: skyblue;
@colorpur: purple;
@font14: 14px;
@font16: 16px;
.box {
color: @color;
font-size: @font14;
a {
color: @colorpur;
font-size: @font16;
}
}
② 如果遇到(交集|伪类|伪元素选择器)
内层选择器的前面没有&符号,则它被解析为父选择器的后代如果有&符号,它就被解析为父元素自身或父元素的伪类
a {
color: @colorpur;
font-size: @font16;
&:hover {
color: burlywood;
}
}
7、Less运算 ¤
任何数字、颜色或变量都可以参与运算。就是Less提供了加(+)、减(-)、乘(*)、除(/)算术运算。
/*less里面写*/
@width : 10 px + 5 ;
div {
border:@width solid red;
}
/*生成的css*/
div {
border: 15px solid red;
}
/*less甚至还可以这样*/
width : ( @width + 5 ) * 2 ;
注意:
乘号(*)和除号(/)的写法要牢记运算符左右两侧要有个空格隔开 1px + 5在新版本的少中,除法有改动,应100px / 10改为(100px / 10),否则没有效果对于两个不同的单位的值之间的运算,运算结果的值取第一个值的单位如果两个值之间只有一个值有单位,则运算结果就取该单位
rem适配方案
【思考】
我们适配的目标是什么?怎么去达到这个目标的?在实际的开发中如何实现?
【答案】
让一些不能等比自适应的元素,达到当设备尺寸发生改变的时候,等比例适配当前设备。使用媒体查询根据不同的设备按比例设置html的字体大小,然后页面元素使用rem做尺寸单位,当html字体大小变化,元素尺寸也会发生变化,从而达到等比缩放的适配。
rem 实际开发适配方案
(1)按照设计稿与设备宽度的比例,动态计算并设置html根标签的 font-size 大小;(媒体查询)。
(2)CSS中,设计稿元素的宽、高、相对位置等取值,按照同等比列换算为rem为单位的值。
rem适配方案技术使用(市场主流)
(1)技术方案1
less媒体查询rem
(2)技术方案2(推荐)
flexible.jsrem
总结:
两种方案的原理都一样的两种方案目前都在使用方案2 更简单,现阶段大家无需了解里面的js代码
1、rem实际开发适配方案1
rem + 媒体查询 + less技术
(1)设计稿常见尺寸宽度
设备常见宽度苹果手机 4 5640 像素苹果手机 6 7 8750 像素苹果 x 11 121170 像素安卓常见 320px、360px、375px、384px、400px、414px、500px、720px、1080px
一般的情况下,我们以一套或两套效果图适应大部分的屏幕,放弃极端屏或对其优雅降级,牺牲一些效果。 现在基本以750px为准。(现在是1080px 2080px 2021年)
(2)动态设置html标签 font-size 大小
真实设计稿是750px假使我们把整个屏幕划分为15等份(划分标准不一,可以是20份,也可以是10等份)每一份作为 html 字体大小,这里是 750/15 = 50px那么在 320px 设备的时候,字体大小为 320/15 = 21.33px用我们页面元素的大小除以不同的 html 字体大小会发现他们比例还是相同的比如我们以 750px 为标准设计稿一个100*100像素的页面元素在750像素屏幕下,就是 100/ 50 转换为rem 是 2rem* 2 rem 比例是1 比 1320像素屏幕下,html字体大小为 21.33 则 2rem = 42.66px 此时宽和高都是 42.66 但是 宽和高的比例还是1 比 1但是已经能实现不同屏幕下,页面元素盒子等比例缩放的效果
(3)元素大小取值方法
最后公式:页面元素的 rem 值 = 页面元素值(px) / (屏幕跨度 / 划分份数)屏幕宽度 / 划分份数 就是 html中 font-size 的大小或者:页面元素的 rem 值 = 页面元素值(px) / html中 font-size 字体大小
2、rem适配方案2
简洁高效的rem适配方案flexible.js
手机淘宝团队出的简洁高效的移动端适配库
我们再也不需要在写不同屏幕的媒体查询,因为里面的 js 可以处理
它的原理是把当前设备划分为10等份,但不同的设备下,比例还是一致的
我们要做的,就是确定好我们当前设备的html文字大小就可以了
比如当前设计稿是750px,那么我们只需要把html文字大小设置为75px(750px / 10)就可以了
里面页面元素rem值:页面元素的px值 / 75
生育的,让flexible.js来去算
github地址:https://github.com/amfe/lib-flexible/