美文网首页
iOS - WKWebView的基本使用

iOS - WKWebView的基本使用

作者: ShIwEn9 | 来源:发表于2019-04-19 12:29 被阅读0次

    引言:在开发过程中,与网页交互的情况很多,我们现在的使用的交互控件基本上都是WKWebView,这个是IOS8之后新增的一个类,也是苹果推崇的一个新的类,其性能和要远超之前的UIWebView,所以我们今天就着重了解一下WKWebView的简单使用。
    其他相关:
    iOS - 获取WKWebView内容的高度并设置字体大小
    iOS - WKWebView点击链接跳转并获取新页面的URL

    简单介绍一下WKWebView的常用熟悉

    // UIWebView 中会自动保存Cookie,如果登录了一次下次再次进入的时候,会记住登录状态
    // 在WKWebView中,新增一个configuration属性,  configuration 让WKWebView知道登录状态,
    // configuration 可以通过已有的Cookie进行设置,也可以通过保存上一次的configuration进行设置
    // WKWebViewConfiguration类中也有一些相应的属性
    @property (nonatomic, readonly, copy) WKWebViewConfiguration *configuration;
     
    // The methods of the WKNavigationDelegate protocol help you track the progress of the web site's main frame navigations and decide load policy for main frame and subframe navigations.
    // WKWebView中,加入了网站导航的概念,这个对象决定主框架导航加载方法协议。
    @property (nullable, nonatomic, weak) id <WKNavigationDelegate> navigationDelegate;
     
    // The WKUIDelegate class provides methods for presenting native user interface 
    elements on behalf of a webpage.
    // WKWebView中,加入了网站窗口的概念,这个对象决了webView窗口的一些方法协议。
    @property (nullable, nonatomic, weak) id <WKUIDelegate> UIDelegate;
     
    A WKBackForwardList object is a list of webpages previously visited in a web view that can be reached by going back or forward.
    // WKWebView中,加入了网站列表的概念,这个WEBBackForwardList对象是以前在Web视图访问的网页,可以通过去后退或前进
    @property (nonatomic, readonly, strong) WKBackForwardList *backForwardList;
    

    话不多说直接撸代码解释:

    //首先需要导入库文件
    #import <WebKit/WebKit.h>
    //同时继承2个代理事件
    <WKNavigationDelegate,WKUIDelegate>
    //创建WKWebView
    //需要注意的是并不能通过故事板或者xib来创建因为根本找不到(这点蛮坑的),所以我们都是手动创建
    WKWebView *webView = [[WKWebView alloc] initWithFrame:[UIScreen mainScreen].bounds];
    self.view = webView;
    SURL *url = [NSURL URLWithString:@"https://www.baidu.com"];
    NSURLRequest *request = [NSURLRequest requestWithURL:url];
    [webView loadRequest:request];
    
    #pragma mark - WKNavigationDelegate,WKUIDelegate
    
    // 页面开始加载时调用
    -(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{
    
    }
    

    我们不光可以加载网页的url,还可以直接使用html中的标签和本地的html 文件

    1.如果html是通过服务器,以url的形式返回,则使用下面这种加载方式
        NSURLRequest *request = [NSURLRequest requestWithURL:url];
        [self.webView loadRequest:request]; 
      补充: 如果加载url出现1002问题,需处理一下url的编码   
     [_urlString stringByAddingPercentEncodingWithAllowedCharacters:[NSCharacterSet characterSetWithCharactersInString:@"#%^{}\"[]|\\<> "].invertedSet]; 
    
    2.除了上面之外的第三种 ----如:带标签的字符串
        [self.webView loadHTMLString:@"<p>Hello</p>" baseURL:nil];
        
    3.如果html为本地文件
    NSURL *fileURL = [[NSBundle mainBundle] URLForResource:@“test.html" withExtension:nil];  
    NSURLRequest *request = [NSURLRequest requestWithURL:fileURL];  
    [self.webView loadRequest:request];
    

    一般我们初步使用WKWebView就是这些,欢迎补充,谢谢!

    相关文章

      网友评论

          本文标题:iOS - WKWebView的基本使用

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