国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 系統 > iOS > 正文

ios下OC與JS交互之WKWebView

2020-07-26 02:54:30
字體:
來源:轉載
供稿:網友

上一篇文章我們使用了JavaScriptCore框架重寫了之前的示例,iOS8蘋果偏愛HTML5,重構了UIWebVIew,給我們帶來了WKWebView,使其性能、穩定性、功能大幅度提升,也更好的支持了HTML5的新特性。這篇文章就們就拿WKWebView來小試牛刀

一、WKWebView Framework

WKWebView的14個類與3個協議:

WKBackForwardList: 之前訪問過的 web 頁面的列表,可以通過后退和前進動作來訪問到。

WKBackForwardListItem: webview 中后退列表里的某一個網頁。

WKFrameInfo: 包含一個網頁的布局信息。

WKNavigation: 包含一個網頁的加載進度信息。

WKNavigationAction: 包含可能讓網頁導航變化的信息,用于判斷是否做出導航變化。

WKNavigationResponse: 包含可能讓網頁導航變化的返回內容信息,用于判斷是否做出導航變化。

WKPreferences: 概括一個 webview 的偏好設置。

WKProcessPool: 表示一個 web 內容加載池。

WKUserContentController: 提供使用 JavaScript post 信息和注射 script 的方法。

WKScriptMessage: 包含網頁發出的信息。

WKUserScript: 表示可以被網頁接受的用戶腳本。

WKWebViewConfiguration: 初始化 webview 的設置。

WKWindowFeatures: 指定加載新網頁時的窗口屬性。

WKWebsiteDataStore: 包含網頁數據存儲和查找。

WKNavigationDelegate: 提供了追蹤主窗口網頁加載過程和判斷主窗口和子窗口是否進行頁面加載新頁面的相關方法。

WKUIDelegate: 提供用原生控件顯示網頁的方法回調。

WKScriptMessageHandler: 提供從網頁中收消息的回調方法。

二、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

創建一個新的WKWebView

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

剩下三個代理方法全都是與界面彈出提示框相關的,針對于web界面的三種提示框(警告框、確認框、輸入框)分別對應三種代理方法。

// 界面彈出警告框- (void)webView:(WKWebView *)webView runJavaScriptAlertPanelWithMessage:(NSString *)message initiatedByFrame:(void (^)())completionHandler;// 界面彈出確認框- (void)webView:(WKWebView *)webView runJavaScriptConfirmPanelWithMessage:(NSString *)message initiatedByFrame:(WKFrameInfo *)frame completionHandler:(void (^)(BOOL result))completionHandler;// 界面彈出輸入框- (void)webView:(WKWebView *)webView runJavaScriptTextInputPanelWithPrompt:(NSString *)prompt defaultText:(nullable NSString *)defaultText initiatedByFrame:(WKFrameInfo *)frame completionHandler:(void (^)(NSString * __nullable result))completionHandler; 

3. WKScriptMessageHandler

這個協議中包含一個必須實現的方法,這個方法是native與web端交互的關鍵,它可以直接將接收到的JS腳本轉為OC或Swift對象。

// 從web界面中接收到一個腳本時調用- (void)userContentController:(WKUserContentController *)userContentController didReceiveScriptMessage:(WKScriptMessage *)message; 

三、使用WKWebView重寫

這里我們和之前的界面做了一點改動,之前OC調用JS的時候是進行彈框處理,這里我在寫的時候,很郁悶,方法可以調用過去,但是唯獨js的alert方法調用沒有效果,所以這里采用了輸出到div的形式,并增加了一個clear按鈕

WKWebView不支持nib文件,所以這里需要使用代碼初始化并加載WebView

WKWebViewConfiguration *config = [[WKWebViewConfiguration alloc] init];config.preferences.minimumFontSize = 18; self.wkWebView = [[WKWebView alloc] initWithFrame:CGRectMake(0, 0, self.view.bounds.size.width, self.view.bounds.size.height/2) configuration:config];[self.view addSubview:self.wkWebView];  NSString *filePath = [[NSBundle mainBundle] pathForResource:@"index" ofType:@"html"];NSURL *baseURL = [[NSBundle mainBundle] bundleURL];[self.wkWebView loadHTMLString:[NSString stringWithContentsOfFile:filePath encoding:NSUTF8StringEncoding error:nil] baseURL:baseURL]; 

OC端:

//1. JS調用OC 添加處理腳本[userCC addScriptMessageHandler:self name:@"showMobile"];[userCC addScriptMessageHandler:self name:@"showName"];[userCC addScriptMessageHandler:self name:@"showSendMsg"]; // 在代理方法中處理對應事件- (void)userContentController:(WKUserContentController *)userContentController didReceiveScriptMessage:(WKScriptMessage *)message {  NSLog(@"%@",NSStringFromSelector(_cmd));  NSLog(@"%@",message.body);   if ([message.name isEqualToString:@"showMobile"]) {    [self showMsg:@"我是下面的小紅 手機號是:18870707070"];  }     if ([message.name isEqualToString:@"showName"]) {    NSString *info = [NSString stringWithFormat:@"你好 %@, 很高興見到你",message.body];    [self showMsg:info];  }     if ([message.name isEqualToString:@"showSendMsg"]) {    NSArray *array = message.body;    NSString *info = [NSString stringWithFormat:@"這是我的手機號: %@, %@ !!",array.firstObject,array.lastObject];    [self showMsg:info];  }} // 2. native調用js- (IBAction)btnClick:(UIButton *)sender {  if (!self.wkWebView.loading) {    if (sender.tag == 123) {      [self.wkWebView evaluateJavaScript:@"alertMobile()" completionHandler:^(id _Nullable response, NSError * _Nullable error) {        //TODO        NSLog(@"%@ %@",response,error);      }];    }         if (sender.tag == 234) {      [self.wkWebView evaluateJavaScript:@"alertName('小紅')" completionHandler:nil];    }         if (sender.tag == 345) {      [self.wkWebView evaluateJavaScript:@"alertSendMsg('18870707070','周末爬山真是件愉快的事情')" completionHandler:nil];    }   } else {    NSLog(@"the view is currently loading content");  }} 

JS端:

function clear() {  document.getElementById('mobile').innerHTML = ''  document.getElementById('name').innerHTML = ''  document.getElementById('msg').innerHTML = ''} //OC調用JS的方法列表function alertMobile() {  //這里已經調用過來了 但是搞不明白為什么alert方法沒有響應  //alert('我是上面的小黃 手機號是:13300001111')  document.getElementById('mobile').innerHTML = '我是上面的小黃 手機號是:13300001111'} function alertName(msg) {  //alert('你好 ' + msg + ', 我也很高興見到你')  document.getElementById('name').innerHTML = '你好 ' + msg + ', 我也很高興見到你'} function alertSendMsg(num,msg) {  //window.alert('這是我的手機號:' + num + ',' + msg + '!!')  document.getElementById('msg').innerHTML = '這是我的手機號:' + num + ',' + msg + '!!'} //JS響應方法列表function btnClick1() {  window.webkit.messageHandlers.showMobile.postMessage(null)} function btnClick2() {  window.webkit.messageHandlers.showName.postMessage('xiao黃')} function btnClick3() {  window.webkit.messageHandlers.showSendMsg.postMessage(['13300001111', 'Go Climbing This Weekend !!!'])} 

四、后記

至此,整個系列的示例已完成,過程中收貨頗豐。每篇文章都會對知識點進行總結,在文章末尾給出示例DEMO的地址。

示例DEMO:OC-JS-WKWebView_jb51.rar

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持武林網。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 丽水市| 山东| 龙山县| 利川市| 六安市| 武城县| 罗江县| 永平县| 将乐县| 仁怀市| 温宿县| 交口县| 西乌珠穆沁旗| 永仁县| 鄢陵县| 车致| 博罗县| 溆浦县| 青田县| 达孜县| 竹山县| 外汇| 四会市| 青河县| 石棉县| 额尔古纳市| 墨玉县| 元朗区| 九台市| 茂名市| 奈曼旗| 湛江市| 蓝山县| 长春市| 上犹县| 五大连池市| 平远县| 门头沟区| 全南县| 萝北县| 望谟县|