前言:
在实际开发中,我们经常会遇到需在应用启动时,越过首页,直接跳转到指定页的操作,主要分为点击应用桌面图标进入,和点击应用推送栏进入两种,接下来将一一讲解。
点击应用桌面图标进入时的跳转到指定页:
在网上看到很多直接获取到当前主控制器,然后执行present跳转的方法:
let vc = UIApplication.sharedApplication().keyWindow?.rootViewController
这种方法在一定程度上能满足页面跳转的需求,缺点是跳转完成后的界面缺少与整个APP统一风格的导航条,需要自己定制返回按钮等等,而如果用 VC 直接使用 Push 方法,却并不会发生页面跳转事件,为了能获得统一导航条,我们可以使用:VC做初始导航控制器
:let nav =UINavigationController(rootViewController: vc) UIApplication.sharedApplication().keyWindow?.rootViewController = nav ,
进行设置,最后在跳转完成后的界面重写 导航条左按钮返回事件,如此完成跳转到指定界面。
点击推送栏进入应用时跳转到指定页:
当我们获得推送时,点击推送栏直接跳到消息详情是一个很常见的操作,在这种情况系主要分为两种:应用在后台运行时,应用被杀死时。 当应用在后台运行时的跳转操作也上文提到过的类似,我们主要讲解第二种情况
在应用被杀死时,点击推送栏的时候,应用首先需要被激活,然后再检测是否有推送消息,所以需要在 APPDelegate 的 - (BOOL)application:(UIApplication)application didFinishLaunchingWithOptions:(NSDictionary)launchOptions 方法中 检测是否有推送消息:
//判断在程序没有运行的情况下收到通知,点击通知跳转页面
if(launchOptions) {
NSDictionary* remoteNotification = [launchOptionsobjectForKey:UIApplicationLaunchOptionsRemoteNotificationKey];
if(remoteNotification) {
NSLog(@"推送消息==== %@",remoteNotification);
//给程序启动留足1秒
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(1*NSEC_PER_SEC)),dispatch_get_main_queue(), ^{
[selfgoToMessageViewWithDic:remoteNotification];
});
// [self goToMssageViewControllerWith:remoteNotification];
}
这里需要注意的是需要使用延迟执行方法给程序留足 启动时间,毕竟如果程序还未启动完成,直接执行跳转代码毫无意外的会造成程序崩溃。
总结:
在开发 消息推送功能时,区别于安卓系统的后台程序不会被系统自动杀死,我们往往会忽略iOS 系统的“自杀”功能,因而会造成闪退现象。而我们的测试妹妹测试时往往在消息刚推送过来时,习惯性立即点开推送栏,嗯,测试通过,没毛病。 因此就理所当然的放掉了,2-3分钟后强大的iOS 系统将后台应用杀死,再去点击推送栏会出现的异常的 现象。
//******************好尴尬,发现这种方法效率太低下,修改一下 2018/04/24*****
在delegate 处的跳转主要是要获取到 对应的 当前顶部控制器, 而由于 delegate 中 keyWindow.RootController 我们还没有设置因此,需要从其它路径获得: 提供思路如下,将自定义的 tabbarController 中延展出一个 进入程序后的控制器数组, 将 delegate 后的登录界面 或者 程序首页 作为 RootController ,再用 RootController 完成跳转;
func getIntoTheApplication(){
self.window = UIWindow()
self.window!.frame = UIScreen.main.bounds;
window?.makeKeyAndVisible()
//加载缓存数据 (用户信息),进入APP
var respViewController:UIViewController!
//需要用来跳转的控制器 vc
if getValuesToAppHome(){
//跳入应用
let tabarVC = SwiftTabBarController()
respViewController = tabarVC
vc = tabarVC.baseVCArray.first!
vc = respViewController.childViewControllers.first!
}
else{
//跳入登录界面
vc = LoginVC()
adsView?.addGestureRecognizer(tap)
}
vc.navigationController?.pushViewController(NextVC, animated: true)
self.window?.rootViewController = vc
}