FMWebViewJavascriptBridge:一个轻量级的 JavascriptBridge

作者 carlSQ 日期 2017年03月14日 阅读次数

简介

FMWebViewJavascriptBridge inspired by react native 是一个轻量级的 JavascriptBridge,只支持 WKWebView iOS 8.0 之后。

image

导入

pod "FMWebViewJavascriptBridge"

使用

自定义 JavascripInterface

  • 自定义 JavascripInterface 类
  • 在暴露的接口前添加FM_EXPORT_METHOD宏
  • 支持的参数可以是 nil NSNull NSString NSNumber NSDictionary NSArray NSDate char int double BOOL
  • 同时支持返回值给Javascrip的回调, 回调的类型FMCallBack,支持参数同上

@implementation JavascripInterface

FM_EXPORT_METHOD(@selector(push:))
- (void)push:(NSUInteger)one {
  [self.viewController.navigationController
      pushViewController:[WKViewController new]
                animated:YES];
  NSLog(@"test push%ld", (unsigned long)one);
}

FM_EXPORT_METHOD(@selector(pop:))
- (void)pop:(NSString *)testArray {
  [self.viewController.navigationController popViewControllerAnimated:YES];
  NSLog(@"pop array %@", testArray);
}

FM_EXPORT_METHOD(@selector(setNavTitle:response:))
- (void)setNavTitle:(NSDictionary *)userInfo response:(FMCallBack)callBack {
  self.viewController.title = userInfo[@"name"];
  callBack(@{@"name":@"carlSQ",@"age":@"26"});
}

添加接口给javascrip调用

用 FMWKWebViewBridge 类中的接口addJavascriptInterface 添加接口道javascrip层

_webViewBridge = [FMWKWebViewBridge wkwebViewBridge:self.webView];
[_webViewBridge addJavascriptInterface:[JavascripInterface new] withName:@"JavascripInterface"];

调用在js层

FM_Require 中的名字是 addJavascriptInterface 中设置的名字


<script>

javascripInterface = FM_Require('JavascripInterface')

javascripInterface.setNavTitle({"name" : "carl", age:"18"},function(responseData) {
                                     setNavTitle.innerHTML = "name:"+responseData.name +"  age:" + responseData.age;
                                     })

</script>

GitHub

GitHub 地址: https://github.com/carlSQ/FMWebViewJavascriptBridge

如有任何知识产权、版权问题或理论错误,还请指正。

转载请注明原作者及以上信息。