移动端vh适配短屏幕手机,兼容一屏显示问题

rem适配

在日常的移动端开发中,设计稿一般为750 物理像素,而我平时开发的时候,习惯以屏幕宽度为375 ,高度为724 为标准( iPhone X 在微信内置浏览器的宽高) ,如下图所示:

该页面是使用 rem 进行适配,此时该图片宽度为 533px,正常我们需要设置其宽度为5.33rem ,当屏幕高度为724时,可以正常一屏显示完全。

html 复制代码
 <body>
   <div class="content">其他内容</div>
   <img class="pic" src="./images/1.png" />
 </body>
css 复制代码
 * {
   margin: 0;
   padding: 0;
 }
 body {
   background-color: skyblue;
 }
 .content {
   margin-top: 8rem
 }
 .pic {
   width: 5.33rem;
 }

短屏手机显示

而当我模拟短屏幕手机进行预览时,设置屏幕高度为667 ,此时屏幕宽度没有变化,那么根元素 htmlfont-size 也不会发生变化,那么造成的结果就是短屏幕手机上会出现滚动条,无法一屏显示。

但是需求是要求内容一屏能显示完全,此时 rem 适配已经没法做到了,在屏幕宽度不变,但是高度变化的情况下,这该怎么进行适配呢?

没错,这里我想到的是 vh 单位,不使用百分比是因为百分比适配是根据父级的宽高进行计算,而 vh 是根据整个屏幕的高度进行计算。

修改 css 如下所示:

css 复制代码
 .content {
   margin-top: 55.249vh;
   /* margin-top: 8rem; */
 }
 .pic {
   /* width: 5.33rem; */
   width: auto;
   height: 28.66vh;
   max-height: 4.15rem;
 }

vh高度适配

利用 vh 对高度进行适配,但是这个 55.249vh28.66vh 是如何这算出来的呢?

首先我是基于 375*724 进行布局,在724 的高度下,图片宽度 5.33rem,高度没设置,那就是使用了图片533px 时的高度,为 415px

724 的高度下,图片高度使用了 415px,那么在屏幕上显示的应该是207.5px,那如果使用 415px 进行vh 换算,应该是 415 / (724x2) x 100,得出的结果约为28.66 ,这个就是对应的 vh 高度。

那么 55.249vh 同理,原来设置的 8rem,也就是相当于 800px,经过换算后得出结果。

而对图片设置 max-height 是为了不让图片一直随着高度变大得拉伸,以免造成图片变形。

此时在短屏幕手机上显示的效果如下图所示,当然 font-size 我这里没处理,有时候 font-size 也可以使用 vh 适配。

相关推荐
琹箐4 分钟前
chrome 插件下载安装;Manifest file is missing or unreadable
前端·chrome
云飞云共享云桌面4 分钟前
面向机械研发:双服务器架构搭配云飞云运行 SolidWorks 方案详解
运维·服务器·前端·网络·架构·制造
乐兮创想 小林18 分钟前
B2B 内容营销的工程化运营:从内容矩阵建模到 SEO/GEO 联动的完整体系
前端·线性代数·矩阵·网站建设·北京网站建设公司
2501_9400417418 分钟前
全栈开发提速指南:可以直接用的项目生成提示词
前端·prompt
BomanGe219 分钟前
NSK直线导轨LH55EL与NH55EM替代指南
前端·javascript·数据库·经验分享·规格说明书
云水一下19 分钟前
Vue.js从零到精通系列(四):前端路由与Vue Router——打造多页单页应用
前端·javascript·vue.js
糯米导航21 分钟前
浏览器解析HTML头部的底层逻辑:从字节流到渲染树的关键一步
前端·html
baozj23 分钟前
把徒步轨迹做成 3D 地形模型:开源工具「印迹 TrailPrint 3D」
前端·vue.js·github
ViavaCos23 分钟前
前端SSE实战指南
前端
Momo__24 分钟前
alien-signals — 驱动 Vue 3.6 响应式引擎的那个 1KB 库
前端·vue.js·响应式编程