前言
一个简单的浏览器,使用到UIToolbar做底部工具栏,在 iOS11 上就有点击无响应的问题。现在发现苹果一到大系统版本,很多 UIView的实现和生命周期都变化,他们系统不用兼容 iOS10,想怎么改就怎么改,没有顾虑,但是我们作为开发者只能受累。
iOS 11
原因:Toolbar 在iOS11默认添加有_UIToolbarContentView
,_UIToolbarContentView _UIButtonBarStackView
覆盖在自定义的按钮上面,导致按钮无响应。
解决
为了解决iOS11(与较低版本兼容)的问题,您只需要在UIToolBar被添加为UI层次结构的子视图之后,调用 layoutIfNeeded方法,UIToolbarContentView会降低到UIToolBar的第一个子视图,然后你就可以将所有的子视图添加到最顶层。
For example in ObjC,
UIToolbar *toolbar = [UIToolbar new];
[self addSubview: toolbar];
[toolbar layoutIfNeeded];
<here one can add all subviews needed>
在创建成功后,使用layoutIfNeeded方法,让_UIToolbarContentView马上生效,这样在添加子视图就没有问题啦。
总结
iOS11 上的 NavigationBar 好像也有相似的结构变化,每一次新系统,用户无愿意升级,开发者为适配要付出更多,一方面是苹果的改变压力在加大,系统的维护也是一个很大工作;另一方面 App 的界面越来越复杂,如果在搭建时没有设计好 UI 框架,部分依赖系统组件功能,导致受到影响也比较大。
参考阅读
- Hello World
- ios - iOS11 UIToolBar Contentview - Stack Overflow
- iOS 11 breaks slacktextviewcontroller · Issue #604 · slackhq/SlackTextViewController
注:本文首发于 iHTCboy's blog,如若转载,请注明来源。