聊聊iOS14适配的那些事
iOS14系统正式版发布前一天,项目升级了一个版本,结果新系统一出就有问题,多个页面面临崩溃,幸好的是,APP用户量不大,升级新版本的用户也不多,于是开始了漫漫的适配道路~
可能不全,仅供参考~
一、造成崩溃的原因,是项目中使用的对象转字符串的JSONKit除了问题,普通的@1,这种NSNumber类型的竟然转不成字符串,报经典错误方法找不到,iOS14之前没有问题
解决方案:项目集成了MJRefresh,项目太老了,一直没有关注过这块,所以将转换的代码换成了[dict mj_JSONString],使用的事MJRefresh库的json转换,请求崩溃问题解决。
二、此次iOS14系统发布转换,选择相册的方式有所更改,将废弃UIImagePickerController,原来的类只支持单选,新的类PHPickerViewController,可支持选择多张照片;另外还有照片权限的问题,增加了选择部分照片的权限,如果用户选择了部分照片,则并不能访问全部的照片。
适配:将工程中使用从相册中选择照片的位置,使用UIImagePickerController的都更改为PHPickerViewController(支持单选和多选);另外如果使用了第三方的选择照片框架,需要及时关注第三方是否适配了iOS14的PHPickerViewController,并及时更新第三方库~
三、iOS14系统,对于UITableViewCell的子视图做了限制,以往使用【cell addSubView:xxx】,完全没有问题,显示和操作都正常,但是iOS14之后,需要严格使用【cell.contentView addSubView:xxx】才可以,否则可能会导致控件不显示或者事件失效的情况。
适配:将工程使用【cell addSubView:xxx】的方式,统统改掉。在修改的过程注意,有些可能是在自定义的cell中做的操作,有些可能是在控制器VC中做的操作,总而言之,使用UITableViewCell的地方,均要修改;另外需要注意的是,有些可能使用了cell.subViews的地方也需要修改,改为cell.contentView.subViews;还有就是使用【cell viewWithTag:xx】的地方也需要修改为【cell.contentView viewWithTag:xx】,否则可能取不到对应的控件。
四、时间选择器的适配,iOS14之后对于时间选择器的样式有所更改,如果还想使用之前的样式,则需要增加一些适配的代码
适配:如果还想要使用以前的样式,则需要修改preferredDatePickerStyle的值
另外,新发现的问题,如果是iOS14对于初始化的设置datePicker的frame并没有效果,需要在设置datePickerMode属性值之后,再设置frame才可以。
五、在适配iOS14的过程中,又发现一个问题,A->B->C...,页面进行跳转,当C及C以后的页面直接使用popToRootViewController的时候,底部的tabBar会消失,然后再进入子级页面,再返回又正常,iOS14之前的并没有此问题。
解决方案:
六、另外设计到iOS14适配的还有定位部分,增加了精准定位和模糊定位的区别,由于自家项目中并不需要精准定位,所以基本上不用做相关的适配,如果你的APP需要做精准定位,则需要对代码和info.plist文件进行对应的适配工作,目前已有文章做了相关的适配,在此就不多说了~
七、UIWebView的问题,苹果12月份之后将全面禁止UIWebView,所以这次顺便一起修改了。
①首先,全局搜索UIWebView,将工程中自己使用的UIWebView更改为WKWebView;
②cd 到工程根目录下,执行命令grep -r UIWebView . (⚠️注意,点前面有空格),全面搜索UIWebView
③针对搜索的结果进行一一修改,若集成的第三方使用了UIWebView,则第三方也需要升级,目前自己工程中使用第三方涉及UIWebView的有IQKeyboardManager、MJRefresh、AFNetworking,以上第三方均做了UIWebView的适配,更新最新版本即可,其中AFNetworking升级到最新版本之后,可能API会有所变动,需要一并修改。
④如果有此问题,提审包上传之后,苹果那边会有邮件提醒,如果没有邮件提醒,那代表UIWebView的适配问题,你的提审包都没有问题了。
八、iOS14之前项目可以运行在模拟器上,使用Xcode12跑iOS14系统的模拟器之后,项目运行报错No architectures to compile for (ONLY_ACTIVE_ARCH=YES, active arch=x86_64, VALID...;另外本人亲测,之前一个项目在Xcode12上跑不起来,提示的都是pods集成的第三方库framework找不到,pod install之后,第三方的framework都是红色,也是用下面方法解决
解决方案:Target --->Build Settings --->搜索VALID_ARCHS,删除即可。
九、iOS14会导致UIPageControl可能不显示的问题
解决方案:使用约束,而不是直接设置frame,或者是确定size.(具体笔者没有亲测,只是设置了约束就可以了)
以上整理,其他笔友如果指教,请留言~