iOS 11在状态栏区域带来了一些新的,也许是不直观的行为,这对使用Apache Cordova或Ionic等工具的开发人员尤为重要。尤其是这种行为变化会影响到任何基于Web的应用程序,这些应用程序在进行iOS 11构建时使用fixed定位标题栏。此文章可帮助您了解iOS 11中的Webview视口。

注意:现有应用程序将继续工作,因为它们始终可以对其视口行为进行更改。这只会影响使用Xcode 9和iOS 11的目标编译的应用程序。
要了解这些变化,我们需要看看它的历史。
状态栏与安全区
在早起版本的iOS上,状态栏只是一个固定屏幕上方的黑色条带,并且是不可触摸的。它属于系统UI的一部分,你的app运行在它的下方空间中。
随着iOS7的推出,状态栏变成了透明的,它的颜色取自应用程序导航栏的颜色。对于运用在webview中的app比如Cordova,通常要判断iOS的版本然后在固定的导航栏上方预留20px的边距,以便正确的填充导航栏。
较新版的iOS对状态栏引入了一些小的修订版本,包括在打电话时状态栏中显示一个额外的横幅,或者应用程序在后台使用定位功能的提示。
在native端,大部分这些兼容措施都被UINavigationBar以及自动布局指南自动解决掉了。屏幕顶部底部布局指南会自动的判断出当前状态栏的正确高度,确保app内容区是『安全区』,状态栏不会覆盖到该区域。如果你根据顶部布局指南使用UINavigationBar,则iOS也会自动将其颜色延伸到状态栏后面。对于Web端来说,没有这样自动化的解决方案。
iOS 11的改变
iOS 11与早起版本的不同在于,webview内容区超出了安全区。这也就是说,如果你有一个头部导航条使用fixed定位元素并且使用top: 0,那么它会在屏幕顶部20px的下方渲染:对齐到状态栏的底部。
当你向下滚动时,它将向上移动到状态栏的下面。
当你向上滚动时,它将会重新跌落到状态栏的下方(此时会留下一个尴尬的间隙,内容会在这20px的间距内展示)
苹果为什么会这么做呢?
如果你看到了iphone X的设计图,你就会有一个印象:iphone X未来有一个不规则的屏幕形状,在屏幕顶部有一段『刘海』,用来放置话筒与相机。如果fixed定位的元素定位到了真正的屏幕顶部,那该元素中间部分会被扬声器与相机覆盖,从而无法访问。
通过对齐到状态栏的底部,可以确保标题中的任何内容都可以访问。
除了现在的应用程序有一个尴尬的标题栏看起来很槽糕,随着页面上下移动,标题栏会被覆盖到状态栏的后面。
iOS 11 修复
幸运的是,苹果给我们一种方式来控制这种形式,通过meta标签。更幸运的是,这种新的视口行为也适用于老的版本,包括弃用的UIWebView!
这个视口选项是:viewport-fit,它有三个可能的值:
所以要将你的标题栏恢复到屏幕的顶部,就像在iOS 10中的状态栏一样,只需要添加viewport-fit=cover到meta中标签中既可。
iPhone X
但是,iPhone X的形状不规则呢?状态栏不在是20px高,并且相机与扬声器都向内凸出,你的标题栏内容将会对用户完全不可用。同样需要注意的是,这也适用于固定在屏幕底部的页脚条,它将会被麦克风挡住。
注意:你的app只能使用iPhone的全屏幕空间,现有的应用程序将显示在顶部和底部的黑色空间的视图框中。
幸运的是,苹果公司增加了一种方法来将安全区域布局指南暴露给CSS。他们添加了一个类似于CSS变量的概念,称为CSS常量。想像这些像系统设置的CSS变量,不能被覆盖。它们可以通过CSS中的constant()函数来访问,该函数已被提交给CSS工作组进行标准化。
四个布局指南常量是:
苹果给我们的最后的礼物是这些变量也被兼容到到UIWebView。
CSS常量示例
比如你有一个固定的头部导航条,你在iOS 10的CSS就像这样:
header {
position: fixed;
top: 0;
left: 0;
right: 0;
bottom: 44px;
padding-top: 20px; /* Status bar height */
}
要是iPhone X或者iOS 11设备可以自动调整,你可以将viewport-fit=cover添加到meta标签中,并在CSS中引入常量:
header {
/* ... */
/* Status bar height on iOS 10 */
padding-top: 20px;
/* Status bar height on iOS 11+ */
padding-top: constant(safe-area-inset-top);
}
对于不理解constant()语法的旧设备使用后备值。你也可以在CSS calc()表达式中使用常量。
您还需要记住为底部导航栏执行此操作。
总结
以上所述是小编给大家介绍的iOS 11中webview的视口,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对网站的支持!
# ios11
# webview
# iOS开发中WebView的基本使用方法简介
# IOS中UIWebView加载Loading的实现方法
# IOS中的webView加载HTML
# 详解iOS webview加载时序和缓存问题总结
# iOS Webview自适应实际内容高度的4种方法详解
# ios开发加载webview显示进度条实例
# iOS 对当前webView进行截屏的方法
# iOS获取cell中webview的内容尺寸
# iOS去除Webview键盘顶部工具栏的方法
# 状态栏
# 应用程序
# 的是
# 如果你
# 标题栏
# 有一个
# 就像
# 将会
# 当你
# 适用于
# 给我们
# 这也
# 苹果公司
# 小编
# 早起
# 导航条
# 也会
# 你可以
# 尤其是
# 这意味着
相关文章:
html制作网站的步骤有哪些,iapp如何添加网页?
制作营销网站公司,淘特是干什么用的?
制作假网页,招聘网的薪资待遇,会有靠谱的吗?一面试又各种折扣?
建站168自助建站系统:快速模板定制与SEO优化指南
如何自定义建站之星网站的导航菜单样式?
Dapper的Execute方法的返回值是什么意思 Dapper Execute返回值详解
如何快速搭建个人网站并优化SEO?
制作证书网站有哪些,全国城建培训中心证书查询官网?
大同网页,大同瑞慈医院官网?
建站之星伪静态规则如何正确配置?
寿县云建站:智能SEO优化与多行业模板快速上线指南
盘锦网站制作公司,盘锦大洼有多少5G网站?
深圳 网站制作,深圳招聘网站哪个比较好一点啊?
制作网站建设的公司有哪些,网站建设比较好的公司都有哪些?
如何快速生成高效建站系统源代码?
建站中国官网:模板定制+SEO优化+建站流程一站式指南
如何在Golang中使用encoding/gob序列化对象_存储和传输数据
长沙做网站要多少钱,长沙国安网络怎么样?
logo在线制作免费网站在线制作好吗,DW网页制作时,如何在网页标题前加上logo?
高防服务器租用首荐平台,企业级优惠套餐快速部署
建站10G流量真的够用吗?如何应对访问高峰?
如何基于云服务器快速搭建网站及云盘系统?
武汉网站如何制作,黄黄高铁武穴北站途经哪些村庄?
如何在阿里云虚拟服务器快速搭建网站?
建站主机是什么?如何选择适合的建站主机?
浙江网站制作公司有哪些,浙江栢塑信息技术有限公司定制网站做的怎么样?
潍坊网站制作公司有哪些,潍坊哪家招聘网站好?
建站之星伪静态规则如何设置?
如何在Tomcat中配置并部署网站项目?
建站之星各版本价格是多少?
山东网站制作公司有哪些,山东大源集团官网?
重庆网站制作公司哪家好,重庆中考招生办官方网站?
如何在云主机上快速搭建网站?
如何批量查询域名的建站时间记录?
如何在服务器上三步完成建站并提升流量?
如何快速搭建二级域名独立网站?
如何做网站制作流程,*游戏网站怎么搭建?
网站制作外包价格怎么算,招聘网站上写的“外包”是什么意思?
大连网站制作公司哪家好一点,大连买房网站哪个好?
详解jQuery停止动画——stop()方法的使用
已有域名如何免费搭建网站?
内部网站制作流程,如何建立公司内部网站?
网站插件制作软件免费下载,网页视频怎么下到本地插件?
如何快速搭建高效服务器建站系统?
重庆市网站制作公司,重庆招聘网站哪个好?
如何访问已购建站主机并解决登录问题?
如何通过二级域名建站提升品牌影响力?
如何优化Golang Web性能_Golang HTTP服务器性能提升方法
实例解析angularjs的filter过滤器
建站上传速度慢?如何优化加速网站加载效率?
*请认真填写需求信息,我们会在24小时内与您取得联系。