jsBridge整理

1.接入?

a.在最外層build.gradle添加 allprojects {repositories {jcenter()maven{url "https://jitpack.io"}}}?

b.在主工程build.gradle添加 dependencies{compile 'com.github.lzyzsd:jsbridge:1.0.4' }

?2.使用

?A.在布局文件中使用BridgeWebView替代WebView?

B.js調(diào)用java?

場(chǎng)景一:自定義函數(shù)調(diào)用廉白,調(diào)用指定的函數(shù),js端與java端的方法名需保持一致

?1)java端注冊(cè)handler,實(shí)現(xiàn)js調(diào)用的回調(diào)?

?BridgeWebView mBridgeWebView = (BridgeWebView)context.findViewById(R.id.xxx); mBridgeWebView.registerHandler(?

?//第一個(gè)參數(shù)與js端定義的方法名保持一致

?"myJsThodName",?

?//第二個(gè)參數(shù)BridgeHandler,接收js傳來(lái)的數(shù)據(jù)并將處理結(jié)果回調(diào)給js端?

?new BridgeHandler(){@overridepublic void handler(String data ,CallbackFunction function){Log.e(TAG,"js端傳來(lái)的數(shù)據(jù)是:"+data);

function.onCallBack("回調(diào)內(nèi)容");} } );

?2)js端定義調(diào)用java的函數(shù)

調(diào)用java

function javaClick(){

var data="給java端數(shù)據(jù)";

window.WebViewJavascriptBridge.callHandler('myJsThodName',

data,function (responseData){birdgeLog('來(lái)自java端回傳的數(shù)據(jù)'+responseData);});? }? ? ??

場(chǎng)景二:默認(rèn)函數(shù)調(diào)用,無(wú)需額外定義方法名??

1)java端設(shè)置默認(rèn)handler? mBridgeWebView.setDefaultHandler(new BridgeHandler(){@overridepublic void handler(String data,CallbackFunction function){Log.e(TAG,"js端傳來(lái)的數(shù)據(jù)是:"+data);function.onCallBack("回調(diào)內(nèi)容);}}? );? ? ? 2)js端定義調(diào)用java的函數(shù)

調(diào)用java用default方式

function javaClick(){var data = "給java端的數(shù)據(jù)"window.WebViewJavascriptBridge.send(data,function (responseData){birdgeLog('來(lái)自java端回傳的數(shù)據(jù)'+responseData);});? }? ??

C. java調(diào)用js?

****js端代碼****

1)注冊(cè)事件監(jiān)聽(tīng)function connectWebViewJavascriptBridge(callback){

//判斷WebViewJavascriptBridge是否存在端三,不存在需要通過(guò)webViewJavascriptBridgeReady來(lái)添加監(jiān)聽(tīng)

if(window.WebViewJavascriptBridge){callback(WebViewJavascriptBridge);}

else{document.addEventListeter('WebViewJavascriptBridgeReady',

function(){callback(WebViewJavascriptBridge);},false);}}

2)注冊(cè)回調(diào)函數(shù),初始化函數(shù)connectWebViewJavascriptBridge(function(bridge){

//場(chǎng)景一:默認(rèn)函數(shù)調(diào)用

bridge.init(function(data,responseCallback){bridgeLog('java端發(fā)來(lái)的數(shù)據(jù)'+data);

var responseData = '回傳給java端的數(shù)據(jù)';

responseCallback(responseData);});

//場(chǎng)景二:自定義函數(shù)調(diào)用bridge.registerHandler(

//與java端方法名保持一致

'myJavaThodName',function(data,responseCallback){bridgeLog('java端發(fā)來(lái)的數(shù)據(jù)'+data);

var responseData = '回傳給java端的數(shù)據(jù)';responseCallback(responseData);});})

js共通函數(shù),log打印函數(shù)

顯示web打印日志

function bridgeLog(logContent) {? ? ? ? ? document.getElementById("log_msg").innerHTML = logContent;? ? ? }

******java端代碼*****

場(chǎng)景一:默認(rèn)函數(shù)調(diào)用mBridgeWebView.send("給js端發(fā)送的數(shù)據(jù)",new CallbackFunction(){@overridepublic void onCallBack(String data){Log.e(TAG,"js端回傳的數(shù)據(jù)"+data);}});

場(chǎng)景二:自定義函數(shù)調(diào)用mBridgeWebView.callHandler(){"myJavaThodName","給js端發(fā)送的數(shù)據(jù)",new CallbackFunction(){@overridepublic void onCallBack(String data){Log.e(TAG,"js端回傳的數(shù)據(jù)"+data);}}}

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末耸弄,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子卓缰,更是在濱河造成了極大的恐慌计呈,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,884評(píng)論 6 492
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件征唬,死亡現(xiàn)場(chǎng)離奇詭異捌显,居然都是意外死亡,警方通過(guò)查閱死者的電腦和手機(jī)总寒,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,347評(píng)論 3 385
  • 文/潘曉璐 我一進(jìn)店門(mén)扶歪,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái),“玉大人摄闸,你說(shuō)我怎么就攤上這事善镰。” “怎么了年枕?”我有些...
    開(kāi)封第一講書(shū)人閱讀 157,435評(píng)論 0 348
  • 文/不壞的土叔 我叫張陵炫欺,是天一觀的道長(zhǎng)。 經(jīng)常有香客問(wèn)我熏兄,道長(zhǎng)竣稽,這世上最難降的妖魔是什么? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 56,509評(píng)論 1 284
  • 正文 為了忘掉前任霍弹,我火速辦了婚禮毫别,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘典格。我一直安慰自己岛宦,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,611評(píng)論 6 386
  • 文/花漫 我一把揭開(kāi)白布耍缴。 她就那樣靜靜地躺著砾肺,像睡著了一般。 火紅的嫁衣襯著肌膚如雪防嗡。 梳的紋絲不亂的頭發(fā)上变汪,一...
    開(kāi)封第一講書(shū)人閱讀 49,837評(píng)論 1 290
  • 那天,我揣著相機(jī)與錄音蚁趁,去河邊找鬼裙盾。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的番官。 我是一名探鬼主播庐完,決...
    沈念sama閱讀 38,987評(píng)論 3 408
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼徘熔!你這毒婦竟也來(lái)了门躯?” 一聲冷哼從身側(cè)響起,我...
    開(kāi)封第一講書(shū)人閱讀 37,730評(píng)論 0 267
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤酷师,失蹤者是張志新(化名)和其女友劉穎讶凉,沒(méi)想到半個(gè)月后,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體山孔,經(jīng)...
    沈念sama閱讀 44,194評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡缀遍,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,525評(píng)論 2 327
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了饱须。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片域醇。...
    茶點(diǎn)故事閱讀 38,664評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖蓉媳,靈堂內(nèi)的尸體忽然破棺而出譬挚,到底是詐尸還是另有隱情,我是刑警寧澤酪呻,帶...
    沈念sama閱讀 34,334評(píng)論 4 330
  • 正文 年R本政府宣布减宣,位于F島的核電站,受9級(jí)特大地震影響玩荠,放射性物質(zhì)發(fā)生泄漏漆腌。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,944評(píng)論 3 313
  • 文/蒙蒙 一阶冈、第九天 我趴在偏房一處隱蔽的房頂上張望闷尿。 院中可真熱鬧,春花似錦女坑、人聲如沸填具。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 30,764評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)劳景。三九已至,卻和暖如春碉就,著一層夾襖步出監(jiān)牢的瞬間盟广,已是汗流浹背。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 31,997評(píng)論 1 266
  • 我被黑心中介騙來(lái)泰國(guó)打工瓮钥, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留筋量,地道東北人烹吵。 一個(gè)月前我還...
    沈念sama閱讀 46,389評(píng)論 2 360
  • 正文 我出身青樓,卻偏偏與公主長(zhǎng)得像毛甲,于是被迫代替她去往敵國(guó)和親年叮。 傳聞我的和親對(duì)象是個(gè)殘疾皇子具被,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,554評(píng)論 2 349

推薦閱讀更多精彩內(nèi)容