WKWebView 与js的交互

自从iOS8之后苹果开始建议替换掉笨重的UIWebView,WKWebView 自从iOS9.0以后,更趋于完善。本文主要介绍WKwebView和js的使用WebViewJavascriptBridge的交互方法

OC 端代码

WebViewJavascriptBridge 早在很久以前就对WK进行了支持,不过本文使用的WK是6.0.2的版本,
pod 'WebViewJavascriptBridge', '~> 6.0.2'
  1. 关于WK的初始化 需要注意的是 在初始化的过程中不必在设置navigationDelegate的代理的。
    WKWebViewConfiguration * config = [[WKWebViewConfiguration alloc] init];
//     设置进程池 用来配置同一个进程池webView的共享数据 如cookies 用户凭证等
    WKProcessPool * pool = [[WKProcessPool alloc] init];
    config.processPool = pool;
    // 进程偏好设置
    WKPreferences * prefer = [[WKPreferences alloc] init];
    prefer.javaScriptEnabled = YES;
//     是否可以不进过用户交互由javascript自动打开窗口
    prefer.javaScriptCanOpenWindowsAutomatically = YES;
    config.preferences = prefer;
    //设置内容交互控制器 用于处理JavaScript与native交互
    WKUserContentController * userController = [[WKUserContentController alloc]init];
    //设置处理代理并且注册要被js调用的方法名称
    [userController addScriptMessageHandler:self name:@"name"];  
    //js注入,注入一个测试方法。
    NSString *javaScriptSource = @"function userFunc(){window.webkit.messageHandlers.name.postMessage( {\"name\":\"HS\"})}";
    WKUserScript *userScript = [[WKUserScript alloc] initWithSource:javaScriptSource injectionTime:WKUserScriptInjectionTimeAtDocumentStart forMainFrameOnly:YES];
    // forMainFrameOnly:NO(全局窗口),yes(只限主窗口)
    [userController addUserScript:userScript];
    config.userContentController = userController;
    self.webView = [[WKWebView alloc] initWithFrame:(CGRect){0 ,0, [UIScreen mainScreen].bounds.size.width ,[UIScreen mainScreen].bounds.size.height } configuration:config];
    [self.view addSubview:self.webView];

    self.webView.UIDelegate = self;
    /**
     *   这个地方如果使用啦jsbrage 就不再需设置navigationDelegate 啦
     */
//    self.webView.navigationDelegate = self;
  1. 初始化bridge 方法
    _bridge = [WKWebViewJavascriptBridge bridgeForWebView:_webView];
// 因为这个地方设置了代理方法  所以切记在WK初始化的时候不要在设置代理了
    [_bridge setWebViewDelegate:self];
  1. 注册js调用oc的方法
-(void)registerNativeFunction
{
      [self shareInit];
}
-(void)shareInit{
    //     handler 中的block 参数是js要调用的oc的实现    handlerName 是oc的实现别名
    [_bridge registerHandler:@"shareInit" handler:^(id data, WVJBResponseCallback responseCallback) {
        // block 中是 oc中的实现方法
//  data 是 js传递给oc的数据
        NSLog(@"webView  使用 wkbridge 交互完成之后 返回的数据 data =%@",data);
        NSString * string = @"WHAHAH";
// responseCallback 是 方法执行完毕之后返回给js的
        responseCallback(string);
    }];
}
  1. oc 调用js的方法
//     oc 调用js的方法
//     不需要参数 不需要回掉方法
//    [_webViewBridge callHandler:@"testJSFunction"];
    // oc 传递给js有参数   不需要回掉方法
//    [_webViewBridge callHandler:@"testJSFunction" data:@"miaowu"];
//     oc 传递给js有参数  而且有回掉方法
    [_webViewBridge callHandler:@"testJSFunction" data:@"一个字符串" responseCallback:^(id responseData) {
        NSLog(@"调用完JS后的回调:%@",responseData);
    }];

JS 端代码

js 在调用oc的方法之前需要首先添加一个js的方法并且调用一次改方法
  • js 中必须包含
function setupWebViewJavascriptBridge(callback) {
                if (window.WebViewJavascriptBridge) { return callback(WebViewJavascriptBridge); }
                if (window.WVJBCallbacks) { return window.WVJBCallbacks.push(callback); }
                window.WVJBCallbacks = [callback];
                var WVJBIframe = document.createElement('iframe');
                WVJBIframe.style.display = 'none';
                WVJBIframe.src = 'wvjbscheme://__BRIDGE_LOADED__';
                document.documentElement.appendChild(WVJBIframe);
                setTimeout(function() { document.documentElement.removeChild(WVJBIframe) }, 0)
            }
// js 调用了一次方法注入js代码 (如果不调用一次会导致oc和js互相调用不会响应) setupWebViewJavascriptBridge(function(bridge) {
                 bridge.registerHandler('testJSFunction', function(data, responseCallback) {
                    alert('JS方法被调用:'+data);
                    responseCallback('js执行过了');
                 })
            })
      
  1. JS 调用oc方法
   function jsCallOCMeathed(){
                WebViewJavascriptBridge.callHandler('shareViewShow',{'foor':'miaowu'},function(response){
                    alert(response);
                })
            }
  1. oc 调用js方法
     setupWebViewJavascriptBridge(function(bridge) {
// 如果有其他的oc调用js的 方法 依照下面的格式进行添加就可以啦
                 bridge.registerHandler('testJSFunction', function(data, responseCallback) {
                    alert('JS方法被调用:'+data);
                    responseCallback('js执行过了');
                 })
            })
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 194,670评论 5 460
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 81,928评论 2 371
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 141,926评论 0 320
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 52,238评论 1 263
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 61,112评论 4 356
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 46,138评论 1 272
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 36,545评论 3 381
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 35,232评论 0 253
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 39,496评论 1 290
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 34,596评论 2 310
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 36,369评论 1 326
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 32,226评论 3 313
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 37,600评论 3 299
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 28,906评论 0 17
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 30,185评论 1 250
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 41,516评论 2 341
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 40,721评论 2 335

推荐阅读更多精彩内容

  • 之前用UIWebView的时候,非常的爽,用JSContext这个类就可以做想做的事,现在要改成WKWebView...
    AgoniNemo阅读 10,960评论 30 12
  • 用普通的UIWebView和JS交互 大概核心代码是这样的 代理方法 想调用的OC方法 然后JS代码 接下来是WK...
    波妞和酱豆子阅读 3,069评论 2 4
  • 事情的起因还是因为项目需求驱动。折腾了两天,由于之前没有UIWebView与JS交互的经历,并且觉得这次在功能上有...
    CocoLeo阅读 697评论 0 3
  • 远0阅读 325评论 0 1
  • 念头,即大脑里出现的想法,情绪,记忆等等以文字,画面表现的瞬间,往往转瞬即逝,但总会被我们知道。 一个普通人每天约...
    广阔12岁阅读 305评论 0 0