WKwebView借助于WebViewJavascriptBridge與js交互

  1. 設(shè)置屬性

    @property WKWebViewJavascriptBridge* bridge;
    
  2. 初始化 WebViewJavascriptBridge

    if (_bridge) { return; }
    //打開(kāi)輸出日志
    [WKWebViewJavascriptBridge enableLogging];
     _bridge = [WKWebViewJavascriptBridge     bridgeForWebView:self.wkWebView];
     [_bridge setWebViewDelegate:self];
    //請(qǐng)求加載網(wǎng)頁(yè),注意:這里h5加載完,會(huì)自動(dòng)執(zhí)行一個(gè)調(diào)用oc的方法
    [self loadExamplePage:self.wkWebView];
    

3.注冊(cè)監(jiān)聽(tīng)js動(dòng)作。將js動(dòng)作在客戶端實(shí)現(xiàn)

  - (void)viewDidLoad {
   //監(jiān)聽(tīng)方法。  js 調(diào)用 OC
    [self jsJumpToLogin];
   }

 //跳轉(zhuǎn)到登錄 jswv_login
 - (void)jsJumpToLogin{
   // 只要js那邊有調(diào)用jswv_login  在 代碼塊中會(huì)自動(dòng)響應(yīng)我們寫(xiě)的方法
 // 當(dāng)然方法名倆端一致 。不然監(jiān)聽(tīng)個(gè)什么東西 ??
[_bridge registerHandler:@"jswv_login" handler:^(id data, WVJBResponseCallback responseCallback) {
    
    //注銷(xiāo)
    [ChildHttpReq Post:ALogout parm:nil showHud:YES sucess:^(NSDictionary *responseObject) {
        
        if ([responseObject[@"result"] isEqual:@200]) {
            //延遲一秒
            dispatch_after(dispatch_time(DISPATCH_TIME_NOW, (int64_t)(1.0 * NSEC_PER_SEC)), dispatch_get_main_queue(), ^{
               
                //跳轉(zhuǎn)到登錄頁(yè)
                LoginViewController *loginVC = [LoginViewController new];
                [self.navigationController pushViewController:loginVC animated:NO];
            });
        }
        
    } failure:^(NSError *error) {
        
        NSLog(@"%@",error);
    }];
}];

}

  1. OC 回調(diào)js
    // // 主動(dòng)調(diào)用 js方法。讓js做動(dòng)作...
 - (void)chooseAll{
     [_bridge callHandler:@"wvjs_bottomLeftBtn"];
  }
  1. wk 在用WebViewJavascriptBridge這個(gè)框架的時(shí)候。 會(huì)因?yàn)槌跏蓟膯?wèn)題,有時(shí)候交互有用有時(shí)候交互又沒(méi)用。此時(shí)應(yīng)該叫后臺(tái)的伙伴。在沒(méi)獲取到的時(shí)候。再重新獲取即可。。。
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容