经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » HTML/CSS » HTML5 » 查看文章
Html5移动端适配IphoneX等机型的方法
来源:jb51  时间:2019/6/26 11:28:33  对本文有异议

先来看下iPhone X机型的样子

上图中,Iphonex机型在头部和底部新增了这两个区域,所以我们需要针对这类机型做些适配,方便我们的webapp的展示
h5做成的移动端页面,常见布局为头部+躯干+底部三栏模式,头部和顶部都是固定定位,躯干可里的内容可以滚动,暂定的布局如下:

  1. <div class="page">
  2. <header></header>
  3. <main></main>
  4. <footer></footer>
  5. </div>

但如果没采用IphoneX机型的新的css属性,而直接采用position: fixed;top:0等常规写法,就会出现头部的导航栏被手机自带的状态栏(显示电量信号等等)遮挡的情况,底部的导航栏被IphoneX自带的呼吸灯(图中手机底部的白条)遮挡的情况,给用户的操作和体验带来困扰,目前针对这类问题,根据自己做过的项目,整理了一下几种解决方案
 

我使用的是vue框架,在index.html页面,我们需要添加

  1. <meta name="viewport" content="width=device-width,viewport-fit=cover">

然后,在公共的app.vue页面,我们每个组件的展示,都是在这里被router-view替换,所以可以在这里处理一下公共的头部顶栏,具体的布局如下:

  1. <template>
  2. <div id="app">
  3. <div class="placeholder_top" :style="{position:fixpositiona?'absolute':'fixed'}"></div>
  4. <router-view class="routerview"></router-view>
  5. </div>
  6. </template>

上面的布局中,我们给class为placeholder_top的div写下如下:

  1. .placeholder_top {
  2. position: fixed;
  3. top: 0;
  4. left: 0;
  5. width: 10rem;
  6. background-color: #303030;
  7. height: constant(safe-area-inset-top);
  8. height: env(safe-area-inset-top);
  9. z-index: 999;
  10. }

这样的话,我们后续,单独的组件,就不用再处理这个顶部栏的问题,那下面,我们就可以处理下前面提到的头部问题,一般头部,我们大多都会封装成公共组件,所以在这里,因为受到我们在app.vue页面插入的那个元素的影响,我们的头部的css写法,也需要略微改动下,头部组件页面布局如下:

  1. <template>
  2. <header>
  3. <div class="title" :style="{position:fixposition?'absolute':'fixed'}">
  4. 导航内容
  5. </div>
  6. <div class="placeholder"></div>
  7. </header>
  8. </template>

页面的css为:

  1. header{
  2. background-color: #303030;
  3. .title{
  4. position: fixed;
  5. top:0;
  6. top: constant(safe-area-inset-top);
  7. top: env(safe-area-inset-top);
  8. left: 0;
  9. height88px;
  10. z-index: 999;
  11. }
  12. .placeholder{
  13. height: 88px;
  14. width: 10rem;
  15. }
  16. }

这样写,这个头部导航栏就会位居于手机状态栏之下了,不会影响到视窗,并且能兼容安卓和ios机型(这类兼容问题,还涉及到ios的系统问题,不过本文暂未涉及)
 

下面再来看下main区域的处理,因为上面header组件已经处理好了,所以main直接如下布局:

  1. main {
  2. padding-top: constant(safe-area-inset-top);
  3. padding-top: env(safe-area-inset-top);
  4. padding-bottom: calc(88px + constant(safe-area-inset-bottom));
  5. padding-bottom: calc(88px + env(safe-area-inset-bottom));

ps:这里说明一下,下面的两行,是用在当前页面没有底部导航栏的情况

  1. padding-bottom: constant(safe-area-inset-bottom);
  2. padding-bottom: env(safe-area-inset-bottom);
  3. },
  4.  

main里面布局好了,直接写内容就可以了,
 

然后在看下底部的footer布局

  1. <template>
  2. <footer>
  3. <div class="foot" :style="{position:fixposition?'absolute':'fixed'}">
  4. 底部内容
  5. </div>
  6. </footer>
  7. </template>

底部内容的css如下:

  1. footer{
  2. position: fixed;
  3. bottom: 0;
  4. left: 0;
  5. width: 10rem;
  6. height: calc(88px + constant(safe-area-inset-bottom));
  7. height: calc(88px + env(safe-area-inset-bottom));
  8. background-color: #303030;
  9. .foot{
  10. position: absolute;
  11. top:0;
  12. left: 0;
  13. width: 10rem;
  14. height: 88px;
  15. }
  16. }

这样写,底部导航foot里的内容,就不会被手机自带的呼吸灯所遮挡

所以可以总结一下,我们在这种webapp适配中,可能需要采用的css写法如下:
 

  1. position: fixed;
  2. top: constant(safe-area-inset-top);
  3. top: env(safe-area-inset-top);
  4. bottom: constant(safe-area-inset-bottom);
  5. bottom: env(safe-area-inset-bottom);
  6. top: calc(1rem + constant(safe-area-inset-top));
  7. top: calc(1rem + env(safe-area-inset-top));
  8. bottom: calc(1rem + constant(safe-area-inset-bottom));
  9. bottom: calc(1rem + env(safe-area-inset-bottom));

ps:在上面的写法中,有写到:style="{position:fixposition?'absolute':'fixed'}",这个是为了解决用户点击输入框,弹出软键盘时,这类固定元素的定位不准的问题,感兴趣的可以研究下,本文暂不讨论
这里可以根据实际需求来采用不同的写法,大体布局逻辑建议不要偏差太大,这样写是为了统一处理,方便维护,另外如果有真机测试,发现布局兼容导致的样式问题,可以采用真机调试方法,用pc端浏览器调试webapp,审查元素,那样基本能解决大部分样式问题,关于真机调试,下回写

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持w3xue。

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号