WebView和H5交互

使用WebViewJavascriptBridge實(shí)現(xiàn)WebView和JavaScript交互。

項(xiàng)目開發(fā)過程中,可能會(huì)遇到WebView和H5交互的情況。我們可以用WebViewJavascriptBridge第三方庫來實(shí)現(xiàn)。
主要有兩個(gè)方法:

- (void)callHandler:(NSString*)handlerName data:(id)data;

這個(gè)方法是發(fā)送消息的方法,當(dāng)OC或者JS需要發(fā)消息給對(duì)方時(shí)苹威,調(diào)用這個(gè)方法,handlerName是發(fā)送消息的名字驾凶,data是需要發(fā)送的數(shù)據(jù)牙甫,對(duì)方需要先用下面這個(gè)方法來注冊,才能接收消息

- (void)registerHandler:(NSString*)handlerName handler:(WVJBHandler)handler;

這個(gè)方法可以理解為是接收消息的方法调违,需要先注冊窟哺,handlerName是消息名,和對(duì)方發(fā)消息的方法名要一樣技肩,handler是個(gè)block且轨,用來接收傳來的消息

這次實(shí)現(xiàn)一個(gè)簡單的功能,點(diǎn)擊H5上面的登錄按鈕虚婿,跳轉(zhuǎn)到原生的登錄頁面旋奢,用戶登錄后,把用戶名和密碼傳給H5然痊。H5里JS代碼使用WebViewJavascriptBridgedemo里的JS代碼
首先至朗,我們在頁面放放置一個(gè)UIWebView,并加載本地的HTML文件

NSString* htmlPath = [[NSBundle mainBundle] pathForResource:@"index" ofType:@"html"];
NSString* appHtml = [NSString stringWithContentsOfFile:htmlPath encoding:NSUTF8StringEncoding error:nil];
NSURL *baseURL = [NSURL fileURLWithPath:htmlPath];
[_webView loadHTMLString:appHtml baseURL:baseURL];

頁面很簡單剧浸,一個(gè)登錄按鈕

WebView.png

我們在JS里面寫按鈕點(diǎn)擊調(diào)用的方法:

var callbackButton =  document.getElementById('buttons').appendChild(document.createElement('button'))                             
callbackButton.innerHTML = '立即登錄'
callbackButton.onclick = function(e) {
                         e.preventDefault()
                         log('JS調(diào)用"testObjcCallback"發(fā)消息給OC')
                         bridge.callHandler('needLogin', {'login': '1'}, function(response) {
                                            log('JS收到OC的回復(fù):', response)
                                            })
                         }

當(dāng)按鈕點(diǎn)擊時(shí)锹引,JS會(huì)發(fā)給OC一個(gè)名為“needLogin”的消息,數(shù)據(jù)為“{"login":"1"}”
當(dāng)然唆香,為了OC能收到消息嫌变,需要在頁面加載完HTML后,注冊一下

- (void)viewDidLoad {
    [super viewDidLoad];

    //加載HTML
    NSString* htmlPath = [[NSBundle mainBundle] pathForResource:@"index" ofType:@"html"];
    NSString* appHtml = [NSString stringWithContentsOfFile:htmlPath encoding:NSUTF8StringEncoding error:nil];
    NSURL *baseURL = [NSURL fileURLWithPath:htmlPath];
    [_webView loadHTMLString:appHtml baseURL:baseURL];

    //打開調(diào)試開關(guān)
    [WebViewJavascriptBridge enableLogging];
    //建立WebView和H5的連接
    _bridge = [WebViewJavascriptBridge bridgeForWebView:_webView];
    //設(shè)置代理
    [_bridge setWebViewDelegate:self];

    //注冊以接收數(shù)據(jù)
    [_bridge registerHandler:@"needLogin" handler:^(id data, WVJBResponseCallback responseCallback) {
     NSLog(@"JS發(fā)來的消息:%@",data);
     if ([data[@"login"] integerValue] == 1) {
            LoginViewController *a = [[UIStoryboard storyboardWithName:@"Main" bundle:nil] instantiateViewControllerWithIdentifier:@"a"];
            a.delegate = self;
            [self.navigationController pushViewController:a animated:YES];
        }
        responseCallback([NSString stringWithFormat:@"收到JS的消息%@",data]);
    }];    
}

我們注冊了一個(gè)名字也為“needLogin”的handle來接收J(rèn)S發(fā)來的消息躬它,并在收到消息后腾啥,返回給JS一個(gè)回復(fù),告訴JS我們已經(jīng)收到它發(fā)送的消息冯吓,在判斷消息里login=1的時(shí)候倘待,我們將會(huì)跳轉(zhuǎn)到登錄頁面,接下來我們點(diǎn)擊按鈕,將會(huì)跳轉(zhuǎn)到登錄頁面

login.png

在調(diào)試窗口我們可以看到JS發(fā)來的消息

log.png

我們在登錄頁面按鈕方法里寫代碼桑谍,把用戶填寫的信息傳給上個(gè)頁面

- (IBAction)login:(id)sender {
    if ([_delegate respondsToSelector:@selector(loginSuccess:password:)]) {
         [_delegate loginSuccess:_userNameTextField.text password:_passwordTextField.text];
    }
    [self.navigationController popViewControllerAnimated:YES];
}

在WebView頁面延柠,接收登錄頁面?zhèn)鱽淼挠脩裘兔艽a,并在這里把用戶名和密碼發(fā)給JS

- (void)loginSuccess:(NSString *)userName password:(NSString *)password{    
    [_bridge callHandler:@"loginSuccess" data:@{@"username":userName,@"password":password} responseCallback:^(id responseData) {
        NSLog(@"%@",responseData);
    }];  
}

同樣的锣披,JS也需要注冊一個(gè)名字為“l(fā)oginSuccess”的handle來接收信息,并且我們在收到消息時(shí),告訴OC我們已成功收到

  bridge.registerHandler('testJavascriptHandler', function(data, responseCallback) {
                                                log('JS收到OC的消息', data)
                                                var responseData = { 'JS':'receive username and password' }
                                                log('JS回復(fù)OC', responseData)
                                                responseCallback(responseData)                                                                                                         
                                                })

我們輸入用戶名為66666雹仿,密碼為88888并點(diǎn)擊登錄


login.png

調(diào)試已經(jīng)有輸出增热,JS已經(jīng)收到我們的信息了


log.png

WebViewJavascriptBridge的JS也會(huì)在H5頁面上打印各個(gè)步驟的輸出:

JS.png

至此,這個(gè)簡單的交互成功完成

GitHub:WebViewVsJS

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末胧辽,一起剝皮案震驚了整個(gè)濱河市峻仇,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌邑商,老刑警劉巖摄咆,帶你破解...
    沈念sama閱讀 211,042評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異人断,居然都是意外死亡吭从,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,996評(píng)論 2 384
  • 文/潘曉璐 我一進(jìn)店門恶迈,熙熙樓的掌柜王于貴愁眉苦臉地迎上來涩金,“玉大人,你說我怎么就攤上這事暇仲〔阶觯” “怎么了?”我有些...
    開封第一講書人閱讀 156,674評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵奈附,是天一觀的道長全度。 經(jīng)常有香客問我,道長斥滤,這世上最難降的妖魔是什么讼载? 我笑而不...
    開封第一講書人閱讀 56,340評(píng)論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮中跌,結(jié)果婚禮上咨堤,老公的妹妹穿的比我還像新娘。我一直安慰自己漩符,他們只是感情好一喘,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,404評(píng)論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著嗜暴,像睡著了一般凸克。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上闷沥,一...
    開封第一講書人閱讀 49,749評(píng)論 1 289
  • 那天萎战,我揣著相機(jī)與錄音,去河邊找鬼舆逃。 笑死蚂维,一個(gè)胖子當(dāng)著我的面吹牛戳粒,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播虫啥,決...
    沈念sama閱讀 38,902評(píng)論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼蔚约,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了涂籽?” 一聲冷哼從身側(cè)響起苹祟,我...
    開封第一講書人閱讀 37,662評(píng)論 0 266
  • 序言:老撾萬榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎评雌,沒想到半個(gè)月后树枫,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,110評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡景东,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,451評(píng)論 2 325
  • 正文 我和宋清朗相戀三年砂轻,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片耐薯。...
    茶點(diǎn)故事閱讀 38,577評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡舔清,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出曲初,到底是詐尸還是另有隱情体谒,我是刑警寧澤,帶...
    沈念sama閱讀 34,258評(píng)論 4 328
  • 正文 年R本政府宣布臼婆,位于F島的核電站抒痒,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏颁褂。R本人自食惡果不足惜故响,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,848評(píng)論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望颁独。 院中可真熱鬧彩届,春花似錦、人聲如沸誓酒。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,726評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽靠柑。三九已至寨辩,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間歼冰,已是汗流浹背靡狞。 一陣腳步聲響...
    開封第一講書人閱讀 31,952評(píng)論 1 264
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留隔嫡,地道東北人甸怕。 一個(gè)月前我還...
    沈念sama閱讀 46,271評(píng)論 2 360
  • 正文 我出身青樓甘穿,卻偏偏與公主長得像,于是被迫代替她去往敵國和親蕾各。 傳聞我的和親對(duì)象是個(gè)殘疾皇子扒磁,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,452評(píng)論 2 348

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