版本信息:

hips ui: 0.1.43

须知:

随着hips ui的迭代,可能会解决适配问题,所以下面的方案是有时效性的。

如果你项目上很紧急,可以直接看第三部分解决方案,复制粘贴代码即可。

一. 无适配情况

自从iPhone X出了刘海屏后,对于我们前端是适配难度又更上一层楼。不知道你有没有遇到过如下情况

1.头尾嵌入边框

2.在适配了头尾之后,scroll框子没做适配,出现最后的内容别下方小黑条遮住的情况

3.适配了iPhoneX,却没有适配iPhoneXs Max

如果,你遇到过以上几种情况,那么就看过来,这篇文章就是为了让你解决诸如此类的问题而诞生的。

首先关于iPhoneX的适配问题,网上有很多文章,其中不乏优秀者,说的详细透彻,这里推荐几篇

H5页面如何适配iPhone X ?腾讯设计师给出了通用解决方案

https://www.jianshu.com/p/438c7c2e5664

他们都讲述的很好,我就不画蛇添足,再去copy一份了。我们要说的是怎样在hips ui的基础上应用适配方案。

二. 适配问题

首先,抛出几个可能会令大家困惑不解的几个问题

  1. 浏览器上无效
body {
padding-top: constant(safe-area-inset-top); //为导航栏+状态栏的高度 88px
padding-left: constant(safe-area-inset-left); //如果未竖屏时为0
padding-right: constant(safe-area-inset-right); //如果未竖屏时为0
padding-bottom: constant(safe-area-inset-bottom);//为底下圆弧的高度 34px
}

有同学会问,为什么我按照上面书写,为啥在浏览器上没有效果。。。

这里是因为这个属性本身在浏览器上是看不出任何效果的,所以不需要疑惑,你只需要照做,然后去手机上看效果即可

2. 就算使用了上述代码,我的页头仍然会处于最上方

这是因为你是在body中使用的,而hips ui的NavBar组件使用的是fixed布局top为0,所以不管怎样,它都会脱离文档流,处于页面的最上方

.hips-view__header--fixed {
position: fixed;
top: 0;
left: 0;
}
  1. popup如何适配
  2. scroll组件的高度如何计算

三. 解决方案

好!了解了上述诸多问题后,我们直接上代码。

No.1 index.html

<meta name="viewport" content="width=device-width, initial-scale=1.0, maximum-scale=1.0, user-scalable=0, viewport-fit=cover">

增加viewport=cover

No.2 _iosFit.styl

.hips-view {
padding-top: constant(safe-area-inset-top) !important;
padding-top: env(safe-area-inset-top) !important;
padding-bottom: constant(safe-area-inset-bottom) !important;
padding-bottom: env(safe-area-inset-bottom) !important;
} .hips-view__header--fixed {
padding-top: constant(safe-area-inset-top) !important;
padding-top: env(safe-area-inset-top) !important;
} .hips-view__footer {
margin-bottom: constant(safe-area-inset-bottom);
margin-bottom: env(safe-area-inset-bottom);
} .hips-popup--bottom, .hips-overlay {
padding-bottom: constant(safe-area-inset-bottom);
padding-bottom: env(safe-area-inset-bottom);
}

既然在body中无效,那我们就在hips ui的hips-view类中加上下间距,既然页面头是绝对定位,那我们就在hips-view__header--fixed中加上下间距,这样我们就解决了适配问题中的两个问题。

然后我们还需要注意其他的一些点,比如View组件的footer,popup组件,我们都要加上响应代码。

至此,我们解决了适配问题的前三个

No.3 滚动条的高度

我们知道在hips ui的scroll组件最外层,是需要加一个div,然后附上固定的height的,这个height当然也是需要考虑iphonex上的padding的,代码如下

.scroll-box {
height: calc(100vh - 13.333vw)
height: calc(100vh - 13.333vw - constant(safe-area-inset-top) - constant(safe-area-inset-bottom))
height: calc(100vh - 13.333vw - env(safe-area-inset-top) - env(safe-area-inset-bottom))
}

上述代码是针对页面只有有一个页头的情况,大家还需根据具体情况减去相应的值

No.4 iPhoneXs Max的适配

因为css的constant函数和env函数在ios11以上已支持,所以我们实际上不需要把代码写在媒体属性里,这样的话,safe-area-inset-top只要这个值有效,那么就会应用上,无效自然没有效果。所以以后我们就不需要专门为iPhoneXs Max或新出的机型写额外的适配代码,一套代码搞定全部。

ok,文章到此为止,希望对大家有所帮助。不足指出,还请指出,相互交流会让我们的方案更加完善。

参考:

适用于hips ui的iPhoneX及以上适配方案的更多相关文章

  1. vivo官网APP全机型UI适配方案

    vivo 互联网客户端团队- Xu Jie 日益新增的机型,给开发人员带来了很多的适配工作.代码能不能统一.apk能不能统一.物料如何选取.样式怎么展示等等都是困扰开发人员的问题,本方案就是介绍不同机 ...

  2. Android 目前最稳定和高效的UI适配方案

    Android系统发布十多年以来,关于Android的UI的适配一直是开发环节中最重要的问题,但是我看到还是有很多小伙伴对Android适配方案不了解.刚好,近期准备对糗事百科Android客户端设计 ...

  3. 给你一个全自动的屏幕适配方案(基于SW方案)!—— 解放你和UI的双手

    Calces系列相关文章:Calces自动实现Android组件化模块构建 前言 屏幕适配一直是移动端开发热议的问题,但是适配方案往往在实际开发的时候会和UI提供的设计稿冲突.本文主要是基于官方推荐的 ...

  4. vue项目中使用了vw适配方案,引入第三方ui框架mint-ui时,适配问题解决

    问题分析: 一般第三方ui框架用的都是不同的适配方式,如果我们使用了vw适配,那么在使用mint-ui框架时,就会发现px单位会被转换成vw,从而导致样式变小的问题,如图 解决方案 网上看到了很多种解 ...

  5. h5 在全屏iphonex中的适配

    iphonex 已经上线有一段时间了,作为业界刘海屏幕第一款机型,导致全屏不能正常的全屏显示了,,所以需要对iphonx 适配,下面就详细说说如何适配 先看一张适配前后的图: iphonex 提供的 ...

  6. android多分辨率多密度下界面适配方案

    前言 Android 设计之初就考虑到了UI在多平台的适配,它本身提供了一套完善的适配机制,随着版本的发展适配也越来越精确,UI适配主要受平台两个因素的影响:屏幕尺寸 (屏幕的像素宽度及像素高度)和屏 ...

  7. Android 屏幕适配方案

    转载请标明出处: http://blog.csdn.net/lmj623565791/article/details/45460089: 本文出自:[张鸿洋的博客] 1.概述 大家在Android开发 ...

  8. 实用Android 屏幕适配方案分享

    转载地址:http://blog.csdn.net/gao_chun/article/details/45645051 真正可用,并且简单易行,可以在多个屏幕大小和屏幕密度上有良好表现的Android ...

  9. Flutter 移动端屏幕适配方案和制作

    flutter_screenutil插件 flutter 屏幕适配方案,让你的UI在不同尺寸的屏幕上都能显示合理的布局! 注意:此插件仍处于开发阶段,某些API可能尚未推出. 安装依赖: 安装之前请查 ...

随机推荐

  1. 2.Bacula Server端安装配置

    1.  Bacula Server端安装配置 1.1.  Bacula Server端安装 1.1.1.  安装bacula依赖包 For Centos6: yum install -y mysql ...

  2. Vue介绍:vue导读3

    一.全局组件 二.父组件传递信息给子组件 三.子组件传递信息给父组件 四.vue项目开发 一.全局组件 <body> <!-- 两个全局vue实例可以不用注册全局组件,就可以使用 - ...

  3. Centos使用光盘yum源

    yum查看所有源 yum repolist all 方法一:本机使用光盘源安装软件的设置 mkdir /media/cdrom mount /dev/cdrom  /media/cdrom vim / ...

  4. 团队第三次作业:Alpha版本第一周小结

    姓名 学号 周前计划安排 每周实际工作记录 自我打分 XXX 061109 1.原型设计与编码任务分配 2.构思程序个性化测试模块的初步实现 1.原型设计与编码任务分配 2.设计了部分类及其成员函数( ...

  5. iview 如何在表格中给操作图标添加Tooltip文字提示?

    项目需要用到的iview 表格中操作项目有各种各样的图标,而各种各样的图标代表不同的操作,面对新用户可能很懵,那如何给这些图标添加Tooltip文字提示? 废话不多讲,直接看代码: <templ ...

  6. CentOS7 内核优化 修改参数

    一:内核简介 内核是操作系统最基本的部分.它是为众多应用程序提供对计算机硬件的安全访问的一部分软件,这种访问是有限的,并且内核决定一个程序在什么时候对某部分硬件操作多长时间. 内核的分类可分为单内核和 ...

  7. 记一次 解决 vue 兼容ie11 的问题

    vue2.0 最近项目需要做到兼容ie11,找问题找半天,于是各种百度, 发现引入 babel-polyfill 还是有问题  空白页面 参考它的配置 ( 最后一句代码为引入的资源路径 )  我跟他差 ...

  8. 【Android-自定义控件】 漂亮的Toast

    修改Toast属性,美化Toast //创建一个Toast Toast toast=new Toast(getApplicationContext()); //创建Toast中的文字 TextView ...

  9. 桥接模式(Bridge)---结构型

    1 基础知识 定义:将抽象部分与它的具体实现部分分离,使得它们都可以独立变化.特征:通过组合的方式建立两个之间的联系而不是继承. 使用场景:抽象和具体实现之间增加更多的灵活性:一个类存在两个(多个)独 ...

  10. SQL Server 基础:ADO.NET

    序言 Connection 主要提供与数据库的连接功能 Command 用于返回数据.修改数据.运行存储过程以及发送或检索参数信息的数据库命令 CommandType 获取或设置Command对象要执 ...