iOS 與 H5交互 (WebViewJavascriptBridge)

官方地址:https://github.com/marcuswestin/WebViewJavascriptBridge

用于在WKWebViews,UIWebViews和WebViews中的Obj-C和JavaScript之間發送消息的iOS / OSX橋接器。

一、安裝

(1)使用CocoaPods安裝

`pod 'WebViewJavascriptBridge', '~> 2.0'`

(2)手動安裝

拖拽WebViewJavascriptBridge文件到工程之中

在出現的對話框中,取消選中“將項目復制到目標組的文件夾”,然后選擇“為任何文件夾創建組”

二、使用

(1)導入頭文件并聲明屬性

//導入頭文件#import "WebViewJavascriptBridge.h"http://聲明屬性@property WebViewJavascriptBridge* bridge;

(2)為(WKWebView, UIWebView, WebView)實例化WebViewJavascriptBridge

self.bridge = [WebViewJavascriptBridge bridgeForWebView:webView];

(3)在Objective-C中注冊處理,并調用JS處理

/* *Objective-C*///注冊處理[self.bridge registerHandler:@"ObjC Echo" handler:^(id data, WVJBResponseCallback responseCallback) {? ? NSLog(@"ObjC Echo called with: %@", data);? ? responseCallback(data);}];//調用處理[self.bridge callHandler:@"JS Echo" data:nil responseCallback:^(id responseData) {? ? NSLog(@"ObjC received response: %@", responseData);}];

(4)復制并粘貼setupWebViewJavascriptBridge方法到JS中

/*

*JS

*/functionsetupWebViewJavascriptBridge(callback){if(window.WebViewJavascriptBridge){returncallback(WebViewJavascriptBridge);}if(window.WVJBCallbacks){returnwindow.WVJBCallbacks.push(callback);}window.WVJBCallbacks=[callback];varWVJBIframe=document.createElement('iframe');WVJBIframe.style.display='none';WVJBIframe.src='https://__bridge_loaded__';document.documentElement.appendChild(WVJBIframe);setTimeout(function(){document.documentElement.removeChild(WVJBIframe)},0)}

(5)最后,調用setupWebViewJavascriptBridge方法,使用bridge注冊處理,并調用Objective-C處理

/*

*JS

*/setupWebViewJavascriptBridge(function(bridge){/* Initialize your app here *///注冊處理bridge.registerHandler('JS Echo',function(data,responseCallback){console.log("JS Echo called with:",data)responseCallback(data)})//調用處理bridge.callHandler('ObjC Echo',{'key':'value'},functionresponseCallback(responseData){console.log("JS received response:",responseData)})})

三、自動引用計數(ARC)

這個庫依賴于ARC,所以如果你在你的項目中使用ARC,一切正常。但是如果你的項目沒有ARC支持,一定要做下一步:

1)在Xcode項目中打開項目設置 - >'Build Phases'

2)展開'Compile Sources'找到所有屬于這個庫的.m文件,請注意此列表中每個源文件前面的'Compiler Flags'

3)為每個文件添加'-fobjc-arc'

現在所有的WVJB文件將被ARC支持編譯

四、API參考

Objective-C API

//為web視圖創建一個javascript bridge[WebViewJavascriptBridge bridgeForWebView:(WKWebVIew/UIWebView/WebView*)webview

//注冊一個名為"handlerName"的處理之后,javascript可以使用WebViewJavascriptBridge.callHandler調用這個處理[bridge registerHandler:(NSString*)handlerName handler:(WVJBHandler)handler]

//調用名為handlerName的javascript處理[bridge callHandler:(NSString*)handlerName data:(id)data]//responseCallback的block,響應javascript的處理[bridge callHandler:(NSString*)handlerName data:(id)data responseCallback:(WVJBResponseCallback)callback]

//(可選)如果需要響應Web視圖的生命周期事件,請設置WKNavigationDelegate / UIWebViewDelegate[bridge setWebViewDelegate:(id)webViewDelegate]

//不安全。通過禁用setTimeout安全檢查來加快橋消息傳遞。只有在您不調用任何JavaScript彈出框功能(警報,確認和提示)時,才能安全地禁用此安全檢查。如果您從橋接的JavaScript代碼調用任何這些函數,該應用程序將掛起[bridge disableJavscriptAlertBoxSafetyTimeout]

Javascript API

//注冊一個名為"handlerName"的處理之后,Objective-C可以使用callHandler: data:或callHandler: data: responseCallback:調用這個處理bridge.registerHandler("handlerName",function(responseData){...})

//調用名為handlerName的Objective-C處理bridge.callHandler("handlerName",data)//responseCallback的函數,響應Objective-C的處理bridge.callHandler("handlerName",data,functionresponseCallback(responseData){...})

//調用bridge.disableJavscriptAlertBoxSafetyTimeout()方法和Objective-C中[bridge disableJavscriptAlertBoxSafetyTimeout]具有與調用相同的效果bridge.disableJavscriptAlertBoxSafetyTimeout()

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市,隨后出現的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 229,963評論 6 542
  • 序言:濱河連續發生了三起死亡事件,死亡現場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機,發現死者居然都...
    沈念sama閱讀 99,348評論 3 429
  • 文/潘曉璐 我一進店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 178,083評論 0 383
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 63,706評論 1 317
  • 正文 為了忘掉前任,我火速辦了婚禮,結果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當我...
    茶點故事閱讀 72,442評論 6 412
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發上,一...
    開封第一講書人閱讀 55,802評論 1 328
  • 那天,我揣著相機與錄音,去河邊找鬼。 笑死,一個胖子當著我的面吹牛,可吹牛的內容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,795評論 3 446
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側響起,我...
    開封第一講書人閱讀 42,983評論 0 290
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后,有當地人在樹林里發現了一具尸體,經...
    沈念sama閱讀 49,542評論 1 335
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內容為張勛視角 年9月15日...
    茶點故事閱讀 41,287評論 3 358
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發現自己被綠了。 大學時的朋友給我發了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 43,486評論 1 374
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 39,030評論 5 363
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質發生泄漏。R本人自食惡果不足惜,卻給世界環境...
    茶點故事閱讀 44,710評論 3 348
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 35,116評論 0 28
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 36,412評論 1 294
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個月前我還...
    沈念sama閱讀 52,224評論 3 398
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 48,462評論 2 378

推薦閱讀更多精彩內容

  • 文|柳初靜 本來你的生活一團糟,無業,單身狗,房奴,孩奴,背叛,離婚,抑郁,雙向情感障礙,空虛……忽然聽到有人說了...
    柳初靜閱讀 99,870評論 213 374
  • 感賞孩子因為沒能按時起床和完成作業而反悔,導致老師來時無法交差而反省,下午一點半即起床做作業,休息片刻繼續學習,用...
    xyldaiqun閱讀 99評論 1 2
  • 我一直說想要看空天獵,H哥說不看不看,有范冰冰我才不去看呢,不知道是不是好多人都是這樣的想法。[捂臉][捂臉]于是...
    薔薇泡泡閱讀 372評論 0 0
  • 如果我想你了,我會用拇指在手機的鍵盤飛速的打上一連串的文字,最后卻始終沒有勇氣按下發送鍵,我害怕會打擾到你,即使我...
    豆得兒得兒丁閱讀 174評論 1 0