前言:
在實(shí)際開(kāi)發(fā)中警儒,我們經(jīng)常會(huì)遇到需在應(yīng)用啟動(dòng)時(shí)竿奏,越過(guò)首頁(yè)袄简,直接跳轉(zhuǎn)到指定頁(yè)的操作腥放,主要分為點(diǎn)擊應(yīng)用桌面圖標(biāo)進(jìn)入泛啸,和點(diǎn)擊應(yīng)用推送欄進(jìn)入兩種,接下來(lái)將一一講解秃症。
點(diǎn)擊應(yīng)用桌面圖標(biāo)進(jìn)入時(shí)的跳轉(zhuǎn)到指定頁(yè):
在網(wǎng)上看到很多直接獲取到當(dāng)前主控制器候址,然后執(zhí)行present跳轉(zhuǎn)的方法:
let vc = UIApplication.sharedApplication().keyWindow?.rootViewController
這種方法在一定程度上能滿足頁(yè)面跳轉(zhuǎn)的需求,缺點(diǎn)是跳轉(zhuǎn)完成后的界面缺少與整個(gè)APP統(tǒng)一風(fēng)格的導(dǎo)航條种柑,需要自己定制返回按鈕等等岗仑,而如果用 VC 直接使用 Push 方法,卻并不會(huì)發(fā)生頁(yè)面跳轉(zhuǎn)事件聚请,為了能獲得統(tǒng)一導(dǎo)航條荠雕,我們可以使用:VC做初始導(dǎo)航控制器
:let? nav =UINavigationController(rootViewController: vc) ?UIApplication.sharedApplication().keyWindow?.rootViewController = nav ,
?進(jìn)行設(shè)置,最后在跳轉(zhuǎn)完成后的界面重寫(xiě) 導(dǎo)航條左按鈕返回事件驶赏,如此完成跳轉(zhuǎn)到指定界面炸卑。
點(diǎn)擊推送欄進(jìn)入應(yīng)用時(shí)跳轉(zhuǎn)到指定頁(yè):
當(dāng)我們獲得推送時(shí),點(diǎn)擊推送欄直接跳到消息詳情是一個(gè)很常見(jiàn)的操作煤傍,在這種情況系主要分為兩種:應(yīng)用在后臺(tái)運(yùn)行時(shí)盖文,應(yīng)用被殺死時(shí)。 當(dāng)應(yīng)用在后臺(tái)運(yùn)行時(shí)的跳轉(zhuǎn)操作也上文提到過(guò)的類似蚯姆,我們主要講解第二種情況
在應(yīng)用被殺死時(shí)五续,點(diǎn)擊推送欄的時(shí)候,應(yīng)用首先需要被激活龄恋,然后再檢測(cè)是否有推送消息疙驾,所以需要在 APPDelegate 的 - (BOOL)application:(UIApplication*)application didFinishLaunchingWithOptions:(NSDictionary*)launchOptions ?方法中 檢測(cè)是否有推送消息:
//判斷在程序沒(méi)有運(yùn)行的情況下收到通知,點(diǎn)擊通知跳轉(zhuǎn)頁(yè)面
if(launchOptions) {
NSDictionary* remoteNotification = [launchOptionsobjectForKey:UIApplicationLaunchOptionsRemoteNotificationKey];
if(remoteNotification) {
NSLog(@"推送消息==== %@",remoteNotification);
//給程序啟動(dòng)留足1秒
dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(1*NSEC_PER_SEC)),dispatch_get_main_queue(), ^{
[selfgoToMessageViewWithDic:remoteNotification];
});
// [self goToMssageViewControllerWith:remoteNotification];
}
這里需要注意的是需要使用延遲執(zhí)行方法給程序留足 啟動(dòng)時(shí)間郭毕,畢竟如果程序還未啟動(dòng)完成荆萤,直接執(zhí)行跳轉(zhuǎn)代碼毫無(wú)意外的會(huì)造成程序崩潰。
總結(jié):
在開(kāi)發(fā) 消息推送功能時(shí),區(qū)別于安卓系統(tǒng)的后臺(tái)程序不會(huì)被系統(tǒng)自動(dòng)殺死链韭,我們往往會(huì)忽略iOS 系統(tǒng)的“自殺”功能偏竟,因而會(huì)造成閃退現(xiàn)象。而我們的測(cè)試妹妹測(cè)試時(shí)往往在消息剛推送過(guò)來(lái)時(shí)敞峭,習(xí)慣性立即點(diǎn)開(kāi)推送欄踊谋,嗯,測(cè)試通過(guò)旋讹,沒(méi)毛病殖蚕。 因此就理所當(dāng)然的放掉了,2-3分鐘后強(qiáng)大的iOS 系統(tǒng)將后臺(tái)應(yīng)用殺死沉迹,再去點(diǎn)擊推送欄會(huì)出現(xiàn)的異常的 現(xiàn)象睦疫。