UIWebView最佳實踐

來自 高性能iOS應(yīng)用開發(fā)

  • UIWebView 可能比較笨重且遲鈍,所以盡可能復(fù)用 web view。同時,UIWebView 也因內(nèi) 存泄漏而知名矫膨。因此,每個應(yīng)用的實例都應(yīng)該足夠好。
    無論何時想向用戶展示新的 URL侧馅,先將內(nèi)容重置為空的 HTML直奋。這樣就能確保 web view 不會將之前的內(nèi)容展示給用戶。要想實現(xiàn)這一功能施禾,在 loadRequest: 方法后調(diào)用 loadHTMLString:baseURL: 即可脚线。
  • 附加一個自定義的UIWebViewDelegate。實現(xiàn)webView:shouldStartLoad WithRequest: navigationType: 方法弥搞。要留意 URL scheme邮绿。如果是 http 或 https 以外的東西,需要注意: 應(yīng)用應(yīng)該知道如何處理這種情況攀例,或警告用戶該網(wǎng)站正試圖脫離應(yīng)用船逮。 這是一個較好的做法,不僅能保證用戶不會突然出現(xiàn)在另一個應(yīng)用當(dāng)中粤铭,同時也對惡意 內(nèi)容進(jìn)行了防護(hù)挖胃,尤其是恰巧要展示一個未知 URL 的內(nèi)容時——例如,在郵件或消息 應(yīng)用中梆惯。
  • 你 可 以 通 過 stringByEvaluatingJavaScriptFromString: 方 法 創(chuàng) 建 一 個 橋 來 連 接 應(yīng) 用 和 JavaScript酱鸭,從而在當(dāng)前已經(jīng)加載的 web 頁面執(zhí)行 JavaScript。如果想要調(diào)用原生應(yīng)用的 方法垛吗,你可以參考之前的處理方法凹髓,使用自定義的 URL scheme。
  • 實現(xiàn)委托的 webView:didFailLoadWithError: 方法怯屉,以保持對所有可能出現(xiàn)的錯誤的緊 密追蹤蔚舀。
  • 實現(xiàn) webView:didFailLoadWithError: 方法來處理特定的錯誤,如例 6-3 所示锨络。如果域名 與 NSURLErrorDomain 相等赌躺,那么 NSError 對象是有不同意義的。
-(void)webView:(UIWebView *)webView didFailLoadWithError:(NSError *)error {
   if([NSURLErrorDomain isEqualToString:error.domain]) {
    switch(error.code) {
      case NSURLErrorBadURL:
        //處理錯誤的URL
      break;
        case NSURLErrorTimedOut:
      //處理超時
      break; //......等等
    } }
}

  • UIWebView 不會通知任何的 HTTP 協(xié)議錯誤羡儿,例如響應(yīng)是 404 或 500 的錯誤礼患。如例 6-4 所示,你需要觸發(fā)兩次調(diào)用失受,第一次使用自定義的 NSURLConnection 調(diào)用讶泰,然 后是通過 web view 的調(diào)用咏瑟。你可以提供一個 NSURLConnection 的委托拂到,然后實現(xiàn) connection:didReceiveResponse: 方法,以便獲取響應(yīng)的相關(guān)信息码泞。
@interface HPWebViewController() <UIWebViewDelegate, NSURLConnectionDataDelegate> 
@property (nonatomic, assign) BOOL shouldValidate;
@end
@implementation HPWebViewController
- (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType) navigationType {
    if(self.shouldValidate) {
      [NSURLConnection connectionWithRequest:request delegate:self]; return NO;
    }
    return YES; 
}

- (void)connection:(NSURLConnection *)connection didReceiveResponse:(NSURLResponse *)response {
    NSInteger status = [(NSHTTPURLResponse *)response statusCode];
    if(status >= 400) {
    //哇!一個錯誤
    //展示警報或隱藏web view——不要展示錯誤的網(wǎng)頁 
    } else {
         self.shouldValidate = NO;
         [self.webView loadRequest:connection.originalRequest];
        }
         [connection cancel];
 }
@end

因為這種技術(shù)需要加載網(wǎng)頁兩次兄旬,所以是不受推薦的。當(dāng)加載頁面時,網(wǎng)頁視圖是可以
展示錯誤的领铐。也許就是點(diǎn)擊了接收的某個消息中的一個連接悯森,用戶才發(fā)起了請求。

  • 嵌入了 UIWebView 的容器應(yīng)該提供以下元素绪撵。
    • 導(dǎo)航按鈕(后退和前進(jìn))瓢姻。
    • 重載按鈕。
    • 取消按鈕音诈,用于取消當(dāng)前正在加載的頁面幻碱。
    • 用于展示頁面標(biāo)題的 UILabel。
    • 用于退出 web view 的關(guān)閉按鈕细溅。如果應(yīng)用(如混合應(yīng)用)只有這一個唯一的界面褥傍,則不需要關(guān)閉按鈕
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市喇聊,隨后出現(xiàn)的幾起案子恍风,更是在濱河造成了極大的恐慌,老刑警劉巖誓篱,帶你破解...
    沈念sama閱讀 206,968評論 6 482
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件朋贬,死亡現(xiàn)場離奇詭異,居然都是意外死亡窜骄,警方通過查閱死者的電腦和手機(jī)兄世,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,601評論 2 382
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來啊研,“玉大人御滩,你說我怎么就攤上這事〉吃叮” “怎么了削解?”我有些...
    開封第一講書人閱讀 153,220評論 0 344
  • 文/不壞的土叔 我叫張陵,是天一觀的道長沟娱。 經(jīng)常有香客問我氛驮,道長,這世上最難降的妖魔是什么济似? 我笑而不...
    開封第一講書人閱讀 55,416評論 1 279
  • 正文 為了忘掉前任矫废,我火速辦了婚禮,結(jié)果婚禮上砰蠢,老公的妹妹穿的比我還像新娘蓖扑。我一直安慰自己,他們只是感情好台舱,可當(dāng)我...
    茶點(diǎn)故事閱讀 64,425評論 5 374
  • 文/花漫 我一把揭開白布律杠。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪柜去。 梳的紋絲不亂的頭發(fā)上灰嫉,一...
    開封第一講書人閱讀 49,144評論 1 285
  • 那天,我揣著相機(jī)與錄音嗓奢,去河邊找鬼讼撒。 笑死,一個胖子當(dāng)著我的面吹牛股耽,可吹牛的內(nèi)容都是我干的椿肩。 我是一名探鬼主播,決...
    沈念sama閱讀 38,432評論 3 401
  • 文/蒼蘭香墨 我猛地睜開眼豺谈,長吁一口氣:“原來是場噩夢啊……” “哼郑象!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起茬末,我...
    開封第一講書人閱讀 37,088評論 0 261
  • 序言:老撾萬榮一對情侶失蹤厂榛,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后丽惭,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體击奶,經(jīng)...
    沈念sama閱讀 43,586評論 1 300
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,028評論 2 325
  • 正文 我和宋清朗相戀三年责掏,在試婚紗的時候發(fā)現(xiàn)自己被綠了柜砾。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 38,137評論 1 334
  • 序言:一個原本活蹦亂跳的男人離奇死亡换衬,死狀恐怖痰驱,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情瞳浦,我是刑警寧澤担映,帶...
    沈念sama閱讀 33,783評論 4 324
  • 正文 年R本政府宣布,位于F島的核電站叫潦,受9級特大地震影響蝇完,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜矗蕊,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,343評論 3 307
  • 文/蒙蒙 一短蜕、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧傻咖,春花似錦朋魔、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,333評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至硬纤,卻和暖如春解滓,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背筝家。 一陣腳步聲響...
    開封第一講書人閱讀 31,559評論 1 262
  • 我被黑心中介騙來泰國打工洼裤, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人溪王。 一個月前我還...
    沈念sama閱讀 45,595評論 2 355
  • 正文 我出身青樓腮鞍,卻偏偏與公主長得像,于是被迫代替她去往敵國和親莹菱。 傳聞我的和親對象是個殘疾皇子移国,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 42,901評論 2 345

推薦閱讀更多精彩內(nèi)容

  • 發(fā)現(xiàn) 關(guān)注 消息 iOS 第三方庫、插件道伟、知名博客總結(jié) 作者大灰狼的小綿羊哥哥關(guān)注 2017.06.26 09:4...
    肇東周閱讀 12,030評論 4 62
  • iOS開發(fā)系列--網(wǎng)絡(luò)開發(fā) 概覽 大部分應(yīng)用程序都或多或少會牽扯到網(wǎng)絡(luò)開發(fā)迹缀,例如說新浪微博、微信等蜜徽,這些應(yīng)用本身可...
    lichengjin閱讀 3,641評論 2 7
  • WebView·開車指南 2016-08-31BugDev 北京市東城區(qū)首席Bug布道師開山之作祝懂,一整月交通事故血...
    53c021c38a1d閱讀 826評論 0 1
  • 用到的組件 1、通過CocoaPods安裝 2拘鞋、第三方類庫安裝 3砚蓬、第三方服務(wù) 友盟社會化分享組件 友盟用戶反饋 ...
    SunnyLeong閱讀 14,602評論 1 180
  • 在實際的工作中是接觸不到angular的,但是公司的前端框架實在是太老了盆色,基本上大家都是在前框架時代在工作灰蛙。 an...
    HH_Game閱讀 287評論 0 1