前言css
Iphone每次退出新尺寸的手机都会掀起一番适配风波,此次没有下巴但有刘海的iPhoneX更是如此,网传横屏下的适配动画更是令很多人汗颜.html
其实对于Native App来讲,适配并不算困难(固然追求酷炫效果另算),官方文档有详细的说明,而对于Web App来讲,主要仍是依靠打开webview的Native App来适配,而这篇文章主要讨论的是Cordova App要如何适配iPhoneX.ios
先上一开始没有适配的效果(下面截图均来自模拟器)web
适配后效果安全
适配步骤以下iphone
更新Cordova插件
布局
首先确认使用的cordova插件有是否包含针对iPhone X的release,例如cordova-plugin-splashscreen
, cordova-plugin-statusbar
等,而我是用的项目模板的插件版本恰好没有出什么问题,因此我也没有深究具体须要更新到哪些版本.动画
而若是使用的是Meteor来打包生成Cordova应用的话,则须要更新Meteor到1.6,而以后运行Meteor也会提醒须要更新哪些插件.spa
这对Native适配很是简单,就加一张图片就行了.对于Cordova也没费多大的事,修改一下config.xml
关于ios启动图配置的部分插件
<platform name="ios"> <!-- 这里只加了针对iphone x的尺寸 1125 * 2436 --> <splash height="2436" src="res/screen/ios/qidong.png" width="1125" /> </platform>
这里的改动主要是添加viewport-fit=cover
,其余部分能够算是Web App的标准配置了.
<meta name="viewport" content="initial-scale=1, width=device-width, height=device-height, maximum-scale=1, minimum-scale=1, user-scalable=no, viewport-fit=cover">
完成上面的配置以后,如今的显示效果应该是这样的
其实离咱们的最终效果已经很近了,观察页面就大概知道是页面的顶部往上顶了,其实上面多出来的区域是iPhoneX特有的,苹果称之为安全区(看对比图三和图二的区别能够看出,上面都有所谓的安全区).
咱们要作的其实就是让页面布局在安全区(Safe Area
)以外的地方.聪明的小伙伴确定已经想到了,对页面加个padding-top
就能够,可是这个padding值是多少呢?确定不会hardcode某个具体数值的.对此苹果提供了safe-area-inset-top
和safe-area-inset-bottom
可用于css来设定具体的安全区域.
// 前两个css规则主要用于完善framework7(模板项目使用UI库),不必定适用其余项目 html, body { height: 100%; overflow: hidden; // box-sizing取决于安全区的padding是加在哪一个元素上 box-sizing: border-box; } html.with-statusbar-overlay .framework7-root { padding-top: 0; } // 主要起效是这里,固然也不必定是加在body上 body { padding-top: constant(safe-area-inset-top); padding-bottom: constant(safe-area-inset-bottom); }
到这里,Cordova项目应该就已经适配好了