1,適配UITableView
if#available(iOS11.0, *) {self.contentInsetAdjustmentBehavior= .neverself.estimatedRowHeight=0self.estimatedSectionHeaderHeight=0self.estimatedSectionFooterHeight=0}else{}
2,適配UIScrollView
if#available(iOS11.0, *) {scrollView?.contentInsetAdjustmentBehavior= .never}else{}
3,UITableView中的sectionHeader或者Footer顯示不正常
還有的發現某些界面tableView的sectionHeader、sectionFooter高度與設置不符的問題,在iOS11中如果不實現-tableView: viewForHeaderInSection:和-tableView: viewForFooterInSection:,則-tableView: heightForHeaderInSection:和- tableView: heightForFooterInSection:不會被調用,導致它們都變成了默認高度,這是因為tableView在iOS11默認使用Self-Sizing,tableView的estimatedRowHeight、estimatedSectionHeaderHeight、estimatedSectionFooterHeight三個高度估算屬性由默認的0變成了UITableViewAutomaticDimension,解決辦法簡單粗暴,就是實現對應方法或把這三個屬性設為0。
4,適配網頁加載不全下面有白邊
if#available(iOS11.0, *) {webView.scrollView.contentInsetAdjustmentBehavior= .never}else{}
5,適配iPhoneX不能鋪滿屏的問題
<1>給Brand Assets添加一張1125*2436大小的圖片
打開Assets.xcassets文件夾,找到Brand Assets
右鍵Show in Finder
添加一張1125*2436大小的圖片
<2>修改Contents.json文件,添加如下內容
{"extent" : "full-screen","idiom" : "iphone","subtype" : "2436h","filename" : "1125_2436.png”,"minimum-system-version" : "11.0","orientation" : "portrait","scale" : "3x"}
6,適配iPhoneX
//適配iPhoneXletLL_iPhoneX = (kScreenW == Double(375.0) && kScreenH == Double(812.0) ?true:false)letkNavibarH = LL_iPhoneX ? Double(88.0) : Double(64.0)letkTabbarH = LL_iPhoneX ? Double(49.0+34.0) : Double(49.0)letkStatusbarH = LL_iPhoneX ? Double(44.0) : Double(20.0)
7,xcode9打包注意事項
xcode9打包版本只能是8.2及以下版本,或者9.0及更高版本
xcode9不支持8.3和8.4版本
xcode9新打包要在構建版本的時候加入1024*1024 AppSore icon
總結
以上所述是小編給大家介紹的iOS11&iPhoneX適配&Xcode9打包注意事項,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復大家的。在此也非常感謝大家對VEVB武林網網站的支持!
新聞熱點
疑難解答