iOS 原生与JS 交互 context

添加JSExport协议的协议,规定的方法变量等,就会对js开放,我们可以通过js调用到

比如: JS方法为  (JS内调用)

testobject.Test1Parameter('参数1')

那么 我们在oc中添加的代理方法就为(OC内定义)

-(void)test1Parameter:(NSString *)message;

如果js是多个参数的话  我们代理方法的所有变量前的名字连起来要和js的方法名字一样比如:

js方法为

testobject.test2Parameter2ndParameter('参数A','参数B')

他有两个参数 那么我们的代理方法 就是把js的方法名  TestTowParameterSecondParameter 任意拆分成两段作为代理方法名(此处我们拆分为 test2Parameter 和 2ndParameter ) 那么我们的代理方法就是

-(void)test2Parameter:(NSString)message1 2ndParameter:(NSString)message2;

首先创建一个类 继承NSObject 并且规定一个协议

//首先创建一个实现了JSExport协议的协议

@protocol TestJSObjectProtocol

//此处我们测试几种参数的情况

-(void)testNOParameter;

-(void)test1Parameter:(NSString)message;

-(void)test2Parameter:(NSString

)message1 2ndParameter:(NSString *)message2;

@end

//让我们创建的类实现上边的协议

@interface TestJSObject : NSObject

@end

类的实现

/#import "TestJSObject.h"

@implementation TestJSObject

//一下方法都是只是打了个log 等会看log 以及参数能对上就说明js调用了此处的iOS 原生方法

-(void)testNOParameter

{

NSLog(@"this is ios testNOParameter");

}

-(void)test1Parameter:(NSString)message

{

NSLog(@"this is ios test1Parameter=%@",message);

}

-(void)test2Parameter:(NSString

)message1 2ndParameter:(NSString *)message2

{

NSLog(@"this is ios test2Parameter=%@  2nd=%@",message1,message2);

}

@end

下面我们在weibview加载完成之后调用测试一下

代码如下:

-(void)webViewDidFinishLoad:(UIWebView *)webView

{

//网页加载完成调用此方法

//首先创建JSContext 对象(此处通过当前webView的键获取到jscontext)

JSContext *context=[webView valueForKeyPath:@"documentView.webView.mainFrame.javaScriptContext"];

//第二种情况,js是通过对象调用的,我们假设js里面有一个对象 testobject 在调用方法

//首先创建我们新建类的对象,将他赋值给js的对象

TestJSObject *testJO=[TestJSObject new];

context[@"testobject"]=testJO;

//同样我们也用刚才的方式模拟一下js调用方法

NSString *jsStr1=@"testobject.testNOParameter()";

[context evaluateScript:jsStr1];

NSString *jsStr2=@"testobject.test1Parameter('参数1')";

[context evaluateScript:jsStr2];

NSString *jsStr3=@"testobject.test1Parameter2ndParameter('参数A','参数B')";

[context evaluateScript:jsStr3];

}


注意:刷新 加载更多时 上下文变化 和注入js调用实际

你可能感兴趣的:(iOS 原生与JS 交互 context)