最新iOS 11 & iPhone X适配方案传送门:10分钟适配 iOS11 & iPhoneX
发现问题
升级Xcode 9 + iOS 11后,发现原本没问题的collectionView和tableView像是中了风一样,头部刷新UI出现了错乱。 查阅发现 iOS11弃用了
automaticallyAdjustsScrollViewInsets
属性,新增contentInsetAdjustmentBehavior
来替代它关于
contentInsetAdjustmentBehavior
@available(iOS 11.0, *) public enum UIScrollViewContentInsetAdjustmentBehavior : Int { case automatic // Similar to .scrollableAxes, but will also adjust the top & bottom contentInset when the scroll view is owned by a view controller with automaticallyAdjustsScrollViewContentInset = YES inside a navigation controller, regardless of whether the scroll view is scrollable case scrollableAxes // Edges for scrollable axes are adjusted (i.e., contentSize.width/height > frame.size.width/height or alwaysBounceHorizontal/Vertical = YES) case never // contentInset is not adjusted case always // contentInset is always adjusted by the scroll view's safeAreaInsets }
UIScrollViewContentInsetAdjustmentBehavior 是一个枚举类型,值有以下几种:
-
automatic
和scrollableAxes一样,scrollView会自动计算和适应顶部和底部的内边距并且在scrollView 不可滚动时,也会设置内边距.
-scrollableAxes
自动计算内边距.
-never
不计算内边距
-always
根据safeAreaInsets 计算内边距很显然,我们这里要设置为
never
开始适配
OC 中
if (@available(iOS 11.0, *)){ _tableView.contentInsetAdjustmentBehavior = UIScrollViewContentInsetAdjustmentNever; _tableView.contentInset = UIEdgeInsetsMake(0, 0, 49, 0);//导航栏如果使用系统原生半透明的,top设置为64 _tableView.scrollIndicatorInsets = _tableView.contentInset; }
swift 中
if #available(iOS 11.0, *) { tableView.contentInsetAdjustmentBehavior = .never tableView.contentInset = UIEdgeInsetsMake(0, 0, 49, 0)//导航栏如果使用系统原生半透明的,top设置为64 tableView.scrollIndicatorInsets = tableView.contentInset }
凡是Scrollview 及 Scrollview子类都会有适配问题,整个工程使用了无数Scrollview的你心理阴影面积一定不小,别担心,其实可以一行代码解决问题:
// AppDelegate 进行全局设置 if (@available(iOS 11.0, *)){ [[UIScrollView appearance] setContentInsetAdjustmentBehavior:UIScrollViewContentInsetAdjustmentNever]; }
适配iOS11 - UITableview UICollectionView MJRefresh下拉刷新错乱
最新推荐文章于 2019-04-28 18:55:23 发布