UIWebView最佳实践

来自 高性能iOS应用开发

  • UIWebView 可能比较笨重且迟钝,所以尽可能复用 web view。同时,UIWebView 也因内 存泄漏而知名。因此,每个应用的实例都应该足够好。
    无论何时想向用户展示新的 URL,先将内容重置为空的 HTML。这样就能确保 web view 不会将之前的内容展示给用户。要想实现这一功能,在 loadRequest: 方法后调用 loadHTMLString:baseURL: 即可。
  • 附加一个自定义的UIWebViewDelegate。实现webView:shouldStartLoad WithRequest: navigationType: 方法。要留意 URL scheme。如果是 http 或 https 以外的东西,需要注意: 应用应该知道如何处理这种情况,或警告用户该网站正试图脱离应用。 这是一个较好的做法,不仅能保证用户不会突然出现在另一个应用当中,同时也对恶意 内容进行了防护,尤其是恰巧要展示一个未知 URL 的内容时——例如,在邮件或消息 应用中。
  • 你 可 以 通 过 stringByEvaluatingJavaScriptFromString: 方 法 创 建 一 个 桥 来 连 接 应 用 和 JavaScript,从而在当前已经加载的 web 页面执行 JavaScript。如果想要调用原生应用的 方法,你可以参考之前的处理方法,使用自定义的 URL scheme。
  • 实现委托的 webView:didFailLoadWithError: 方法,以保持对所有可能出现的错误的紧 密追踪。
  • 实现 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 协议错误,例如响应是 404 或 500 的错误。如例 6-4 所示,你需要触发两次调用,第一次使用自定义的 NSURLConnection 调用,然 后是通过 web view 的调用。你可以提供一个 NSURLConnection 的委托,然后实现 connection:didReceiveResponse: 方法,以便获取响应的相关信息。
@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——不要展示错误的网页 
    } else {
         self.shouldValidate = NO;
         [self.webView loadRequest:connection.originalRequest];
        }
         [connection cancel];
 }
@end

因为这种技术需要加载网页两次,所以是不受推荐的。当加载页面时,网页视图是可以
展示错误的。也许就是点击了接收的某个消息中的一个连接,用户才发起了请求。

  • 嵌入了 UIWebView 的容器应该提供以下元素。
    • 导航按钮(后退和前进)。
    • 重载按钮。
    • 取消按钮,用于取消当前正在加载的页面。
    • 用于展示页面标题的 UILabel。
    • 用于退出 web view 的关闭按钮。如果应用(如混合应用)只有这一个唯一的界面,则不需要关闭按钮
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 发现 关注 消息 iOS 第三方库、插件、知名博客总结 作者大灰狼的小绵羊哥哥关注 2017.06.26 09:4...
    肇东周阅读 12,262评论 4 61
  • iOS开发系列--网络开发 概览 大部分应用程序都或多或少会牵扯到网络开发,例如说新浪微博、微信等,这些应用本身可...
    lichengjin阅读 3,726评论 2 7
  • WebView·开车指南 2016-08-31BugDev 北京市东城区首席Bug布道师开山之作,一整月交通事故血...
    53c021c38a1d阅读 853评论 0 1
  • 用到的组件 1、通过CocoaPods安装 2、第三方类库安装 3、第三方服务 友盟社会化分享组件 友盟用户反馈 ...
    SunnyLeong阅读 14,721评论 1 180
  • 在实际的工作中是接触不到angular的,但是公司的前端框架实在是太老了,基本上大家都是在前框架时代在工作。 an...
    HH_Game阅读 299评论 0 1