什么是JS桥

JavaScript017

什么是JS桥,第1张

桥接模式将抽象部分与实现部分分离开来,使两者都可以独立的变化,并且可以一起和谐地工作。抽象部分和实现部分都可以独立的变化而不会互相影响,降低了代码的耦合性,提高了代码的扩展性。

基本理论:

桥接模式定义:将抽象部分与它的实现部分分离,使它们都可以独立地变化。

更多详解可以查看:网页链接,希望可以帮到你

首先确保一份已经配好功能的html文件:

1.初始化一个webview(viewdidload)

UIWebView* webView = [[UIWebView alloc] initWithFrame:self.view.bounds]

[self.view addSubview:webView]

2.将此webview与WebViewJavascriptBridge关联(viewdidload)

if (_bridge) { return}

[WebViewJavascriptBridge enableLogging]

_bridge = [WebViewJavascriptBridge bridgeForWebView:webView webViewDelegate:self handler:^(id data, WVJBResponseCallback responseCallback) {

NSLog(@"ObjC received message from JS: %@", data)

responseCallback(@"Response for message from ObjC")

}]

ps:此时你的webview就与js搭上桥了。下面就是方法的互调和参数的互传。

(1) js调oc方法(可以通过data给oc方法传值,使用responseCallback将值再返回给js)

[_bridge registerHandler:@"testObjcCallback" handler:^(id data, WVJBResponseCallback responseCallback) {

NSLog(@"testObjcCallback called: %@", data)

responseCallback(@"Response from testObjcCallback")

}]

这里注意testObjcCallback这个方法的标示。html那边的命名要跟ios这边相同,才能调到这个方法。当然这个名字可以两边商量着自定义。简单明确即可。

(2)oc调js方法(通过data可以传值,通过 response可以接受js那边的返回值 )

id data = @{ @"greetingFromObjC": @"Hi there, JS!" }

[_bridge callHandler:@"testJavascriptHandler" data:data responseCallback:^(id response) {

NSLog(@"testJavascriptHandler responded: %@", response)

}]

注意这里的 testJavascriptHandler也是个方法标示。

(3)oc给js传值(通过 response接受返回值 )

[_bridge send:@"A string sent from ObjC to JS" responseCallback:^(id response) {

NSLog(@"sendMessage got response: %@", response)

}]

(4)oc给js传值(无返回值)

[_bridge send:@"A string sent from ObjC after Webview has loaded."]