Html5移动端适配IphoneX等机型的方法


Posted in HTML / CSS onJune 25, 2019

先来看下iPhone X机型的样子

Html5移动端适配IphoneX等机型的方法

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

<div class="page">
    <header></header>
    <main></main>
    <footer></footer>
  </div>

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

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

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

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

<template>
<div id="app">
<div class="placeholder_top" :style="{position:fixpositiona?'absolute':'fixed'}"></div>
<router-view  class="routerview"></router-view>
</div>
</template>

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

.placeholder_top {
  position: fixed;
  top: 0;
  left: 0;
  width: 10rem;
  background-color: #303030;
  height: constant(safe-area-inset-top);
  height: env(safe-area-inset-top);
  z-index: 999;
}

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

<template>
<header>
    <div class="title" :style="{position:fixposition?'absolute':'fixed'}">
    导航内容
    </div>
    <div class="placeholder"></div>
    </header>
</template>

页面的css为:

header{
background-color: #303030;
    .title{
    position: fixed;
    top:0;
    top: constant(safe-area-inset-top);
    top: env(safe-area-inset-top);
    left: 0;
    height:88px;
    z-index: 999;
    }
    .placeholder{
    height: 88px;
    width: 10rem;
    }
}

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

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

main {
padding-top: constant(safe-area-inset-top);
padding-top: env(safe-area-inset-top);
padding-bottom: calc(88px + constant(safe-area-inset-bottom));
padding-bottom: calc(88px + env(safe-area-inset-bottom));

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

padding-bottom: constant(safe-area-inset-bottom);
padding-bottom: env(safe-area-inset-bottom);
},

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

然后在看下底部的footer布局

<template>
<footer>
    <div class="foot" :style="{position:fixposition?'absolute':'fixed'}">
    底部内容
    </div>
</footer>
</template>

底部内容的css如下:

footer{
    position: fixed;
    bottom: 0;
    left: 0;
    width: 10rem;
    height: calc(88px + constant(safe-area-inset-bottom));
    height: calc(88px + env(safe-area-inset-bottom));
    background-color: #303030;
    .foot{
    position: absolute;
    top:0;
    left: 0;
    width: 10rem;
    height: 88px;
    }
}

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

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

position: fixed;
    top: constant(safe-area-inset-top);
    top: env(safe-area-inset-top);
    bottom: constant(safe-area-inset-bottom);
    bottom: env(safe-area-inset-bottom);
    top: calc(1rem + constant(safe-area-inset-top));
    top: calc(1rem + env(safe-area-inset-top));
    bottom: calc(1rem + constant(safe-area-inset-bottom));
    bottom: calc(1rem + env(safe-area-inset-bottom));

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

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

HTML / CSS 相关文章推荐
CSS3 完美实现圆角效果
Jul 13 HTML / CSS
使用CSS3来绘制一个月食图案
Jul 18 HTML / CSS
HTML5+CSS3实例 :canvas 模拟实现电子彩票刮刮乐代码
Dec 30 HTML / CSS
HTML5 Canvas实现文本对齐的方法总结
Mar 24 HTML / CSS
HTML5中FileReader接口使用方法实例详解
Aug 26 HTML / CSS
html5 canvas-2.用canvas制作一个猜字母的小游戏
Jan 07 HTML / CSS
HTML5之SVG 2D入门8—文档结构及相关元素总结
Jan 30 HTML / CSS
html5实现多文件的上传示例代码
Feb 13 HTML / CSS
基于html5绘制圆形多角图案
Apr 21 HTML / CSS
Canvas获取视频第一帧缩略图的实现
Nov 11 HTML / CSS
HTML基础-标签分类(闭合标签,空标签,块级元素,行内元素,行级块元素,可替换元素)
Mar 31 HTML / CSS
关于CSS自定义属性与前端页面的主题切换问题
Mar 21 HTML / CSS
微信小程序之html5 canvas绘图并保存到系统相册
Jun 20 #HTML / CSS
使用canvas一步步实现图片打码功能的方法
Jun 17 #HTML / CSS
解析html5 canvas实现背景鼠标连线动态效果代码
Jun 17 #HTML / CSS
一文彻底解决HTML5页面中长按保存图片功能
Jun 10 #HTML / CSS
使用html5 canvas绘制圆环动效
Jun 03 #HTML / CSS
高清屏中使用Canvas绘图出现模糊的问题及解决方法
Jun 03 #HTML / CSS
H5最强接口之canvas实现动态图形功能
May 31 #HTML / CSS
You might like
PHP安全的URL字符串base64编码和解码
2014/06/19 PHP
利用PHP将图片转换成base64编码的实现方法
2016/09/13 PHP
[原创]php集成安装包wampserver修改密码后phpmyadmin无法登陆的解决方法
2016/11/23 PHP
php数据库的增删改查 php与javascript之间的交互
2017/08/31 PHP
鼠标滑上去后图片放大浮出效果的js代码
2011/05/28 Javascript
Javascript弹出窗口的各种方法总结
2013/11/11 Javascript
点击弹出层效果&amp;弹出窗口后网页背景变暗效果的实现代码
2014/02/10 Javascript
JavaScript中的比较操作符&gt;、=、
2014/12/31 Javascript
浅谈javascript的调试
2015/01/28 Javascript
JavaScript调用客户端Java程序的方法
2015/07/27 Javascript
JS判断是否长按某一键的方法
2016/03/02 Javascript
jQuery.Validate表单验证插件的使用示例详解
2017/01/04 Javascript
原生js实现淘宝放大镜效果
2020/10/28 Javascript
JS/jQuery实现获取时间的方法及常用类完整示例
2019/03/07 jQuery
webpack4之如何编写loader的方法步骤
2019/06/06 Javascript
js实现文章目录索引导航(table of content)
2020/05/10 Javascript
JS前端基于canvas给图片添加水印
2020/11/11 Javascript
在Python3中使用asyncio库进行快速数据抓取的教程
2015/04/02 Python
python3+PyQt5实现柱状图
2018/04/24 Python
Anaconda 离线安装 python 包的操作方法
2018/06/11 Python
对numpy下的轴交换transpose和swapaxes的示例解读
2019/06/26 Python
python 实现矩阵按对角线打印
2019/11/29 Python
mysql的最长数据库名,表名,字段名可以是多长
2014/04/21 面试题
如果有两个类A,B,怎么样才能使A在发生一个事件的时候通知B
2016/03/12 面试题
护士自荐信
2013/10/25 职场文书
酒店司机岗位职责
2013/12/14 职场文书
办公室前台的岗位职责
2013/12/20 职场文书
网络事业创业计划书范文
2014/01/09 职场文书
大学活动总结范文
2014/04/29 职场文书
运动会演讲稿
2014/05/07 职场文书
安全生产知识竞赛活动总结
2014/07/07 职场文书
2015元旦主持词开场白和结束语
2014/12/14 职场文书
绵山导游词
2015/02/05 职场文书
用React Native制作一个简单的游戏引擎
2021/05/27 Javascript
Python中的 Set 与 dict
2022/03/13 Python
面试官问我Mysql的存储引擎了解多少
2022/08/05 MySQL