亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 系統 > 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

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

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
欧美国产亚洲精品久久久8v| 欧美大尺度激情区在线播放| 久久免费视频在线| 98精品国产自产在线观看| 性色av一区二区三区红粉影视| 亚洲天堂成人在线| 欧美日韩激情视频8区| 伊人久久久久久久久久久| 深夜成人在线观看| 国产精品无码专区在线观看| 亚洲91精品在线| 成人免费看黄网站| 日本三级韩国三级久久| 国产亚洲欧美日韩美女| 欧美精品激情视频| 北条麻妃在线一区二区| 久久久影视精品| 超在线视频97| 国产精品三级久久久久久电影| 国产欧美精品一区二区三区介绍| 欧美日本国产在线| 欧美亚洲国产日韩2020| 亚洲成色777777在线观看影院| 国产欧美日韩亚洲精品| 欧美肥臀大乳一区二区免费视频| 国产精品成人av在线| 亚洲韩国日本中文字幕| 中文字幕一区日韩电影| 国产精品美女久久| 亚洲成成品网站| 国产精品视频大全| 最近2019好看的中文字幕免费| 午夜精品视频网站| 视频在线一区二区| 亚洲精品中文字幕有码专区| 国产一区二区视频在线观看| 国产精品久久久久久av下载红粉| 91禁国产网站| 欧美日韩在线视频一区二区| 国产精品久久久久久亚洲调教| 亚洲另类xxxx| 国产一区二区三区日韩欧美| 国产日产欧美a一级在线| 色一情一乱一区二区| 欧美高清视频免费观看| 日韩av网站大全| 国产日韩精品一区二区| 亚洲精品小视频| 国产成人自拍视频在线观看| 在线观看中文字幕亚洲| 欧美一区二区色| 91香蕉嫩草神马影院在线观看| 国产精品视频26uuu| 日韩欧美在线网址| 欧美肥老太性生活视频| 亚洲18私人小影院| 欧美成人精品在线观看| 欧美理论电影在线观看| 亚洲影视九九影院在线观看| 欧美精品少妇videofree| 日韩色av导航| 成人免费视频a| 日韩精品在线观看一区二区| 日韩成人av在线播放| 国产成人综合精品| www.亚洲人.com| 国外视频精品毛片| 日韩**中文字幕毛片| 2024亚洲男人天堂| 欧美成人激情图片网| 精品小视频在线| 日日噜噜噜夜夜爽亚洲精品| 亚洲欧美一区二区三区情侣bbw| 日本乱人伦a精品| 一区二区三区视频免费| 国产成人精品999| 欧美亚洲视频一区二区| 日本久久久a级免费| 欧美午夜精品久久久久久久| 亚洲天堂男人天堂女人天堂| 这里精品视频免费| 亚洲欧洲成视频免费观看| 久久国产精品久久久久久久久久| 2019中文字幕在线观看| 久久久精品国产一区二区| 亚洲精品视频网上网址在线观看| 欧美亚洲视频一区二区| 精品露脸国产偷人在视频| 韩国美女主播一区| 永久免费看mv网站入口亚洲| 精品少妇v888av| 精品亚洲一区二区三区四区五区| 亚洲最大的免费| 青青青国产精品一区二区| 国产精品高精视频免费| 国产精品稀缺呦系列在线| 国产成人精品最新| 亚洲国产精品大全| 久久久久国产精品免费网站| 中日韩美女免费视频网址在线观看| 国产精品色婷婷视频| 日韩网站在线观看| 亚洲第一视频网| 欧美性xxxx极品hd欧美风情| 国产精品高清在线观看| 久久久久久久久国产精品| 青青草成人在线| 国产日产欧美精品| 日韩免费视频在线观看| 欧美国产高跟鞋裸体秀xxxhd| 91香蕉国产在线观看| xxxxx91麻豆| 国产成人精品999| 国产精欧美一区二区三区| 成人免费网站在线| 亚洲国产精品va在看黑人| 国产免费亚洲高清| 精品国产网站地址| 久久久久国色av免费观看性色| 国产精品免费观看在线| 97碰在线观看| 欧美亚洲免费电影| 日韩精品免费电影| 久久久久久久成人| 97视频在线播放| 日韩在线免费观看视频| 亚洲国产一区二区三区四区| 亚洲综合日韩中文字幕v在线| 成人性生交xxxxx网站| 亚洲国模精品一区| 亚洲国产免费av| 国产欧美一区二区三区视频| 国产欧美日韩中文字幕在线| 在线视频一区二区| 国内精品伊人久久| 国产精品黄页免费高清在线观看| 在线观看中文字幕亚洲| 久久精品这里热有精品| 26uuu另类亚洲欧美日本老年| 日韩在线观看网站| 久久影院中文字幕| 欧美一区三区三区高中清蜜桃| 欧亚精品中文字幕| 91av视频在线播放| 亚洲的天堂在线中文字幕| 国产精品香蕉国产| 成人97在线观看视频| 668精品在线视频| 日韩中文字幕网站| 久久精品视频亚洲| 国产亚洲精品久久久久动| 一区二区三区四区在线观看视频| 亚洲激情视频在线| 日韩欧美成人区| 国内精品久久久久久久久| 国产日韩欧美中文在线播放| 97国产精品人人爽人人做| 日韩精品一二三四区| 日韩av在线一区二区| 色七七影院综合| 亚洲欧洲一区二区三区在线观看| 国产成人小视频在线观看| 国产精品久久久久久久久久小说| 岛国视频午夜一区免费在线观看|