详情点击 有啥功能
To run the example project, clone the repo, and run pod install
from the Example directory first.
GCWKWebViewJSBridge is available through CocoaPods. To install it, simply add the following line to your Podfile:
Add pod 'GCWKWebViewJSBridge' to your Podfile.
Run pod install or pod update.
Import <GCWKWebViewJSBridge/GCWKWebViewJSBridge.h>.
pod 'GCWKWebViewJSBridge', '~> 0.1.1'
- Download all the files in the GCWKWebViewJSBridge subdirectory.
- Add the source files to your Xcode project.
- Import GCWKWebViewJSBridge.h
strivever
1.WKWebView深度交互,并提供了js日志输出到xcode控制台; 2.提供JS调用OC;提供OC调用JS; 3.OC通过注入变量给JS传参数; 4.OC通过注册JS函数,供JS调用; 5.js给OC传参;通过拦截链接,进行交互,进行了统一封装,统一管理你的拦截回调;
//注册xcode控制台 输出web控制台信息
[bridge registCaptureJSConsoleLog];
[bridge registCaptureJSExceptionLog];
//注册JS调用ocShare函数
[bridge registJSMethod:@"ocCamera" nativeHandler:^(NSString * _Nonnull messageName, id _Nonnull messageBody) {
NSLog(@"%@",messageBody);
}];
//批量注册JS调用oc函数
[bridge registJSMethods:@[@"ocShare",@"getUserJson"] nativeHandler:^(NSString * _Nonnull messageName, id _Nonnull messageBody) {
NSLog(@"%@:%@",messageName,messageBody);
}];
//oc向JS注入实例变量,可用来向h5注入用户token,信息等等
NSDictionary * userInfo = @{@"uid":@"10086",@"name":@"中国移动",@"age":@"22",@"token":@"oidahnfjabfiabfuaojfbaiufbafo"};
[bridge nativeUploadJSArguments:userInfo filedName:@"uoloadUser" inTime:WKUserScriptInjectionTimeAtDocumentStart];
//oc向JS注入参数,可用来向h5注入一个带参数返回值的函数,供h5调用
NSArray * lists = @[@"周1",@"周2",@"周3",@"周4"];
[bridge nativeUploadJSArguments:lists useMethod:@"getOCMessage" inTime:WKUserScriptInjectionTimeAtDocumentStart];
//注册拦截www.baidu.com
[bridge registInterceptURLKey:@"www.baidu.com" handler:^(NSString * _Nonnull keyURL, NSString * _Nonnull URL) {
}];
//批量注册拦截www.baidu.com
[bridge registInterceptURLKeys:@[@"share:123",@"share:12345",@"share://info#"] handler:^(NSString * _Nonnull keyURL, NSString * _Nonnull URL) {
NSLog(@"%@====\n%@",keyURL,URL);
}];
GCWKWebViewJSBridge is available under the MIT license. See the LICENSE file for more info.