美文网首页
[转]WKWebView的新特性与使用

[转]WKWebView的新特性与使用

作者: 0o冻僵的企鹅o0 | 来源:发表于2018-03-29 16:26 被阅读27次

    在WWDC2014中,苹果推出了最新的iOS8系统,其中也伴随着很多控件的更新与升级。其中全新的WebKit库让人很是兴奋。本文也将讲解到WebKit中更新的WKWebView控件的新特性与使用方法,它很好的解决了UIWebView存在的内存、加载速度等诸多问题。

    一、WKWebView新特性

    • 在性能、稳定性、功能方面有很大提升(最直观的体现就是加载网页是占用的内存,模拟器加载百度与开源中国网站时,WKWebView占用23M,而UIWebView占用85M);
    • 允许JavaScript的Nitro库加载并使用(UIWebView中限制);
    • 支持了更多的HTML5特性;
    • 高达60fps的滚动刷新率以及内置手势;
    • 将UIWebViewDelegate与UIWebView重构成了14类与3个协议(查看苹果官方文档);

    二、初始化

    1. 首先需要引入WebKit库

    #import <WebKit/WebKit.h>
    

    2. 初始化方法分为以下两种

    // 默认初始化
    - (instancetype)initWithFrame:(CGRect)frame;
    
    // 根据对webview的相关配置,进行初始化
    - (instancetype)initWithFrame:(CGRect)frame 
                    configuration:(WKWebViewConfiguration *)configuration NS_DESIGNATED_INITIALIZER;
    

    3. 加载网页与HTML代码的方式与UIWebView相同,代码如下:

    WKWebView *webView = [[WKWebView alloc] initWithFrame:self.view.bounds];
    [webView loadRequest:[NSURLRequest requestWithURL:[NSURL URLWithString:@"http://www.baidu.com"]]];
    [self.view addSubview:webView];
    

    三、 WKWebView的代理方法

    1. WKNavigationDelegate

    该代理提供的方法,可以用来追踪加载过程(页面开始加载、加载完成、加载失败)、决定是否执行跳转。

    // 页面开始加载时调用
    - (void)webView:(WKWebView *)webView didStartProvisionalNavigation:(WKNavigation *)navigation;
    // 当内容开始返回时调用
    - (void)webView:(WKWebView *)webView didCommitNavigation:(WKNavigation *)navigation;
    // 页面加载完成之后调用
    - (void)webView:(WKWebView *)webView didFinishNavigation:(WKNavigation *)navigation;
    // 页面加载失败时调用
    - (void)webView:(WKWebView *)webView didFailProvisionalNavigation:(WKNavigation *)navigation;
    

    页面跳转的代理方法有三种,分为(收到跳转与决定是否跳转两种)

    // 接收到服务器跳转请求之后调用
    - (void)webView:(WKWebView *)webView didReceiveServerRedirectForProvisionalNavigation:(WKNavigation *)navigation;
    // 在收到响应后,决定是否跳转
    - (void)webView:(WKWebView *)webView decidePolicyForNavigationResponse:(WKNavigationResponse *)navigationResponse decisionHandler:(void (^)(WKNavigationResponsePolicy))decisionHandler;
    // 在发送请求之前,决定是否跳转
    - (void)webView:(WKWebView *)webView decidePolicyForNavigationAction:(WKNavigationAction *)navigationAction decisionHandler:(void (^)(WKNavigationActionPolicy))decisionHandler;
    

    2. WKUIDelegate

    // 创建一个新的WebView
    - (WKWebView *)webView:(WKWebView *)webView
    createWebViewWithConfiguration:(WKWebViewConfiguration *)configuration
       forNavigationAction:(WKNavigationAction *)navigationAction
            windowFeatures:(WKWindowFeatures *)windowFeatures;
    

    剩下三个代理方法全都是与界面弹出提示框相关的,针对于web界面的三种提示框(警告框、确认框、输入框)分别对应三种代理方法。下面只举了警告框的例子。

    /**
     *  web界面中有弹出警告框时调用
     *
     *  @param webView           实现该代理的webview
     *  @param message           警告框中的内容
     *  @param frame             主窗口
     *  @param completionHandler 警告框消失调用
     */
    - (void)webView:(WKWebView *)webView
    runJavaScriptAlertPanelWithMessage:(NSString *)message
    initiatedByFrame:(void (^)())completionHandler;
    

    3. WKScriptMessageHandler

    这个协议中包含一个必须实现的方法,这个方法是提高App与web端交互的关键,它可以直接将接收到的JS脚本转为OC或Swift对象。(当然,在UIWebView也可以通过“曲线救国”的方式与web进行交互,著名的Cordova框架就是这种机制)

    // 从web界面中接收到一个脚本时调用
    - (void)userContentController:(WKUserContentController *)userContentController
          didReceiveScriptMessage:(WKScriptMessage *)message
    {
        [super userContentController:userContentController didReceiveScriptMessage:message];
        //服务器固定格式写法 window.webkit.messageHandlers.名字.postMessage(内容);
        //客户端写法 message.name isEqualToString:@"名字"]
        if ([message.name isEqualToString:@"returnApp"]) {
            [self.navigationController popViewControllerAnimated:YES];
        }else if ([message.name isEqualToString:@"checkingPaper"]) {
            NSLog(@"%@", message.body);
            NSDictionary *dic = message.body;
            if ([UtilTools isExistAndIsDictionary:dic])
            {
                EDCheckingModel paperType = [dic[@"paperType"] integerValue];
                NSString *squareId = dic[@"squareId"];
                NSString *subjectId = dic[@"subjectId"];
                ...
            }
            
        }
       
    }
    

    四、WKWebView加载JS

    // 图片缩放的js代码
    NSString *js = @"var count = document.images.length;for (var i = 0; i < count; i++) {var image = document.images[i];image.style.width=320;};window.alert('找到' + count + '张图');";
    // 根据JS字符串初始化WKUserScript对象
    WKUserScript *script = [[WKUserScript alloc] initWithSource:js injectionTime:WKUserScriptInjectionTimeAtDocumentEnd forMainFrameOnly:YES];
    // 根据生成的WKUserScript对象,初始化WKWebViewConfiguration
    WKWebViewConfiguration *config = [[WKWebViewConfiguration alloc] init];
    [config.userContentController addUserScript:script];
    _webView = [[WKWebView alloc] initWithFrame:self.view.bounds configuration:config];
    [_webView loadHTMLString:@"<head></head><img src='http://www.nsu.edu.cn/v/2014v3/img/background/3.jpg' />"baseURL:nil];
    [self.view addSubview:_webView];
    
    

    五、本文Demo下载

    https://github.com/saitjr/WKWebViewSimpleDemo.git

    六、关于JS的加载或WebView的其他使用技巧,可查看一下文章:

    使用Safari对WebView进行调试

    WebView加载HTML图片大小自适应与文章自动换行

    参考资料:

    http://nshipster.cn/wkwebkit/

    http://www.cocoachina.com/webapp/20141121/10277.html

    http://blog.csdn.net/cyforce/article/details/37657009

    相关文章

      网友评论

          本文标题:[转]WKWebView的新特性与使用

          本文链接:https://www.haomeiwen.com/subject/ozomcftx.html