移动端页面布局方式,简单记录一下

1、视口

视口就是浏览器显示页面=内容的屏幕区域
视口分为布局视口、视觉视口、理想视口


①三种视口介绍
(1)布局视口(了解)

  • 用于早期的PC端页面在手机上显示的问题
  • 这个视口分辨率设置基本为980px,所以PC上的网页大多都能在手机上呈现,只不过元素看上去很小,一般默认可以通过手动缩放网页

(2)视觉视口(了解)

  • 视觉视口就是用户正在看到的网站的区域

(3)理想视口

  • 为了使网站在移动端有理想的浏览和阅读宽度而设定
  • 理想视口对设备来讲,是最理想的视口尺寸
  • 需要手动添加meta视口标签通知浏览器操作

②meta视口标签
(1)主要目的:布局视口的宽度应该与理想视口的宽度一致,简单理解就是设备有多宽,布局的视口就多宽。
(2)语法:meta name="viewport" content="width=device-width,user-scalable=no,initial-scale=1.0,maximum-scale=1.0,minimum-scale=1.0">
在这里插入图片描述
(3)标准的viewport设置

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

①物理像素和物理像素比

  • 物理像素点指的是屏幕显示的最小颗粒,是物理真实存在的。
  • 开发时的1px不是一定等于1个物理像素的
  • PC端页面,1px等于1个物理像素的,但是移动端不一定
  • 一个px的能显示的物理像素点的个数,称为物理像素比或屏幕像素比
  • PC端和早期的手机屏幕:1CSS像素 = 1物理像素的,后来,Retina(视网膜屏幕)一种显示技术,可以把更多的物理像素点压缩至一块屏幕里,从而达到更高的分辨率,并提高屏幕显示的细腻程度。

②多背图

  • 对于一张50px*50px的图片,在手机Retina屏幕中打开,按照上面的物理像素比放大倍数,这样会造成图片模糊
  • 在标准的viewport设置中,使用倍图来提高图片网站质量,解决在高清设备中的模糊问题。
  • 通常使用二倍图,也有3倍图、4倍图…看实际开发
  • 背景图片注意缩放问题,例如如果使用二倍图,就要将大一倍的图缩小:
    在这里插入图片描述
    background-size:参数该属性规定背景图片的尺寸
    参数:
    (1)写两个参数:就分别表示宽和高
    (2)只写一个参数,就表示宽,高就省略了
    (3)cover:高宽等比例拉伸,拉伸到完全覆盖盒子位置
    (4)contain:高宽等比例拉伸,当宽度或高度铺满盒子就不再进行拉伸了,可能有空白部分
3、移动端开发选择

①单独制作移动端页面
②响应式兼容PC端

4、移动端技术解决方案

①移动端浏览器基本以webkit内核为主,可以放心使用H5标签和C3样式。


②CSS初始化
移动端CSS初始化推荐使用normalize.css/

  • 保护了有价值的默认值
  • 修复了浏览器的bug
  • 是模块化的
  • 拥有详细的文档

官网:http://necolas.github.io/normalize.css/


③移动端中的盒子模型
在移动端中盒子模型用的是box-sizing,与传统的content-box盒子模型相比,box-sizing中的padding和border不会撑大盒子了
在这里插入图片描述
在这里插入图片描述


④特殊样式
在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

5、移动端常见布局

①单独制作移动端页面

  • 流式布局(百分比布局)
  • flex弹性布局(强烈推荐)
  • less+rem+媒体查询布局

②响应式兼容PC端

  • 媒体查询
  • bootstarp
6、流式布局

①流式布局就是百分比布局,也称为非固定像素布局。
通过盒子的宽度设置成百分比来根据屏幕的宽度进行伸缩,不受固定像素的限制,内容向两侧填充。
流式布局方式是移动web开发使用的比较常见的布局方式。

为了保护内容不因为过分伸缩被破坏,可以加两个属性:
max-width 最大宽度(max-height 最大高度)
min-width 最小宽度(min-height 最小高度)


②开发前准备工作
(1)设置视口标签
(2)移动端CSS初始化
推荐使用normalize.css/
在这里插入图片描述


③二倍精灵图做法
(1)先把精灵图等比例缩放为原来的一半
(2)之后根据大小测量坐标
(3)background-size中也要写精灵图原来的一半

7、flex弹性布局
①flex与传统布局比较

传统布局:

  • 兼容性好
  • 布局繁琐
  • 局限性,不能再移动端很好的布局

flex弹性布局

  • 操作方便,布局极为简单,移动端应用广泛
  • PC端浏览器支持情况较差

建议:
1、如果是PC端页面布局,我们还是传统布局
2、如果是移动端或者不考虑兼容性问题的PC端页面布局ÿ

  • 1
    点赞
  • 32
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
抱歉,由于您的问题涉及到技术问题,我可以为您提供相关的帮助和解答。以下是一个可能的示例代码,以实现类似于聊天记录的时间显示“今天”或“昨天”在移动端的Vue页面布局: <template> <div> <div v-for="(record, index) in chatRecords" :key="index"> <div>{{ record.content }}</div> <div>{{ formatDate(record.timestamp) }}</div> </div> </div> </template> <script> export default { data () { return { chatRecords: [ { content: 'Hello!', timestamp: new Date() }, { content: 'Hi there!', timestamp: new Date(Date.now() - 86400000) // 24 hours in milliseconds (yesterday) }, { content: 'How are you?', timestamp: new Date(Date.now() - 172800000) // 48 hours in milliseconds (2 days ago) } ] } }, methods: { formatDate (timestamp) { const today = new Date() const date = new Date(timestamp) if (date.getDate() === today.getDate()) { // if today return '今天 ' + this.formatTime(date) } else if (date.getDate() === today.getDate() - 1) { // if yesterday return '昨天 ' + this.formatTime(date) } else { return this.formatDateAndTime(date) } }, formatTime (date) { const hours = date.getHours().toString().padStart(2, '0') const minutes = date.getMinutes().toString().padStart(2, '0') return `${hours}:${minutes}` }, formatDateAndTime (date) { const year = date.getFullYear().toString() const month = (date.getMonth() + 1).toString().padStart(2, '0') const day = date.getDate().toString().padStart(2, '0') const time = this.formatTime(date) return `${year}-${month}-${day} ${time}` } } } </script> 请注意,此示例仅仅是一个演示,您需要根据实际情况进行适当的修改和调整,以实现您的业务需求。如果您需要更多的帮助和指导,请不要犹豫联系我或其他开发者和技术专家。谢谢!

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

东篱_Y

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

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

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

打赏作者

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

抵扣说明:

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

余额充值