【前端】移动端布局基础

移动端布局基础知识

一. 视口

🔰视口:就是浏览器显示页面内容的屏幕区域
🔰视口可分为布局视口,视觉视口,理想视口。
🔰我们移动端布局想要的理想视口就是手机屏幕有多宽,我们的布局视口就有多宽。
🔰想要理想视口,我们需要给我们的移动端页面添加meta视口标签


(一) meta 视口标签

🔰<meta name="viewport" content="width=device-width, user-scalable=no, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0">

属性 解析说明
width 宽度设置的是viewport宽度,可以设置device-width特殊值
initial-scale 初始缩放比,大于0的数字
maximum-scale 最大缩放比,大于0的数字
initial-scale 最小缩放比,大于0的数字
minimum-scale 用户是否可以缩放,yes或no(1或0)

(二) 标准的viewport设置

🔰视口宽度和设备保持一致
🔰视口的默认缩放比例1.0
🔰不允许用户自行缩放
🔰最大允许的缩放比例1.0
🔰最小的缩放比例1.0



二. 二倍图

🔰对于一张图片,在手机屏中打开,物理像素比会放大倍数,这会造成图片模糊;
🔰在标准viewport设置中,使用倍图来提高图片质量,解决在高清设备中的模糊问题;

img {
    
	/*原始图片100*100px*/
	width: 50px;
	height: 100px;  }

(一) 背景缩放 background-size

🔰background-size规定背景图像的尺寸

background-size: 背景图片宽度 背景图片高度;
background-size: 500px 200px;
/*1. 只写一个参数,肯定是宽度,高度忽略了,会等比例缩放*/
background-size: 500px;
/*2. 里面的单位可以跟% 相对于父盒子来说的;*/
background-size: 50%;
/*3. cover 等比例拉伸,要完全覆盖div盒子,可能有部分背景图片显示不全*/
background-size: cover;
/*4. contain 高度和宽度等比例拉伸,当宽度或者高度铺满div盒子就不再进行拉伸了,可能有部分空白区域*/
background-size: contain;

🔰单位:长度 | 百分比 | cover | contain
🔰cover把背景图像扩展至足够大,以使背景图像完全覆盖背景区域。
🔰contain把图像扩展至最大尺寸,以使其宽度和高度完全适应内容区域。



三. 移动端开发选择

(一) 单独移动端页面(主流)

🔰通常情况下,网址域名前面添加m(modile)可以打开移动端。通过判断设备,如果是移动设备打开,则跳到移动端页面。


(二) 响应式兼容PC移动端

🔰通过判断屏幕宽度来改变样式,以适应不同终端。
🔰缺点:制作麻烦,需要花很大精力去调兼容性问题。



四. 移动端技术解决方案

(一) CSS初始化 normalize.css

🔰移动端CSS初始化推荐使用 normalize.css/
◉normalize.css:保护了有价值的默认值
◉normalize.css:修复了浏览器bug
◉normalize.css:是模块化的
◉normalize.css:拥有详细的文档
🔰官网地址:http://necolas.github.io/normalize.css/


(二) CSS3 盒子模型 box-sizing

🔰传统模式宽度计算:盒子宽度 = CSS中设置的width+border+padding
🔰CSS3盒子模型:盒子的宽度 = CSS中设置的宽度里面包含了border和paddingCSS3中的盒子模型,padding和border不会撑大盒子了

div {
    
	/*CSS3盒子模型*/
	box-sizing: border-box;
	/*传统盒子模型*/
	box-sizing: content-box; }

🔰移动端可以全部CSS3盒子类型;
🔰PC端如果完全需要兼容,我们就用传统模式,如果不考虑兼容性,我们就选择CSS3盒子模型。


(三) 移动端特殊样式

🔰点击高亮我们需要清除,设置为 transparent 完成透明

a {
     -webkit-tap-highlight-color: transparent;}

在这里插入图片描述 ==》在这里插入图片描述
🔰在移动端浏览器默认的外观在ios上加上这个属性才能给按钮和输入框自定义样式;

input {
     -webkit-appearance: none;}

在这里插入图片描述==》在这里插入图片描述
🔰禁止长按页面时的弹出菜单;

img, a {
     -webkit-touch-callout: none;}

在这里插入图片描述



五. 移动端常见布局

(一) 移动端技术类型

🔰单独制作移动端页面(主流)

  1. 流式布局(百分比布局)
  2. flex 弹性布局(强烈推荐)
  3. less + rem + 媒体查询布局
  4. 混合布局

🔰响应式页面兼容移动端(其次)

  1. 媒体查询
  2. bootstarp

(二) 流式布局(百分比布局)

🔰流式布局,就是百分比布局,也称非固定像素布局;
🔰通过盒子的宽度设置成百分比来根据屏幕的宽度来进行伸缩,不受固定像素的限制,内容向两侧填充
🔰流式布局方式是移动web开发使用的比较常见的布局方式;
🔰max-width: 90px;:最大宽度(max-height 最大高度)
🔰min-width: 90px;:最小宽度(min-height 最小高度)


(三) flex 布局

1. 传统布局与 flex 布局

🔰传统布局

  1. 兼容性好
  2. 布局繁琐
  3. 局限性,不能再移动端很好的布局

🔰flex 弹性布局

  1. 操作方便,布局简单,移动端应用广泛
  2. PC 端浏览器支持情况较差
  3. IE 11 或者更低版本,不支持或仅部分支持

🔰建议:

  1. 如果是PC端页面布局,我们还是传统布局
  2. 如果是移动端或者不考虑兼容性问题的PC端页面布局,我们还是使用flex弹性布局<
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

码字小萌新♡

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值