首页 > 代码库 > OC 和 js 交互

OC 和 js 交互

首先导入 

<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #d12f1b } span.s1 { color: #78492a } span.s2 { }</style>

#import <JavaScriptCore/JavaScriptCore.h>

 

声明 对象

<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #bb2ca2 } span.s1 { } span.s2 { color: #000000 } span.s3 { color: #703daa }</style>

@property (nonatomic, strong) JSContext *context;

 

1, oc调用js的方法并获取参数

<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo } p.p2 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; min-height: 16.0px } p.p3 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #d12f1b } p.p4 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #4f8187 } span.s1 { } span.s2 { color: #bb2ca2 } span.s3 { color: #703daa } span.s4 { color: #000000 } span.s5 { color: #4f8187 } span.s6 { color: #3d1d81 } span.s7 { color: #d12f1b }</style>

- (void)webViewDidFinishLoad:(UIWebView *)webView{

    

//初始化 context

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

    

    __block JJMessageViewController *messageSelf = self;

  //  details  是js的方法

    self.context[@"details"] = ^{

        

        NSArray *arg = [JSContext currentArguments];

        //获取的参数 也可以是id类型 (这里是将jsvalue转换成nsstring)

 

        for (JSValue *jsVal in arg) {

        

            NSLog(@"%@", jsVal.toString);

        //jsVal.toString 就是js传递的参数(这里是字符串)  也可以是一个数组或者字典

            

            messageSelf.messageTitle = jsVal.toString;

        }

        

    };

    

}

 

剩下的就在下面的这个方法中操作

<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo } p.p2 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #703daa } p.p3 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #d12f1b } p.p4 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; min-height: 16.0px } p.p5 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #4f8187 } p.p6 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #3d1d81 } p.p7 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #bb2ca2 } span.s1 { } span.s2 { color: #bb2ca2 } span.s3 { color: #703daa } span.s4 { color: #000000 } span.s5 { color: #3d1d81 } span.s6 { color: #d12f1b } span.s7 { color: #4f8187 }</style>

- (BOOL)webView:(UIWebView *)webView shouldStartLoadWithRequest:(NSURLRequest *)request navigationType:(UIWebViewNavigationType)navigationType {

    NSString *str = request.URL.absoluteString;;

    NSLog(@"url --- %@",str);

       

        NSRange range = [str rangeOfString:@"ios://jwzhangjie"];

        if (range.location != NSNotFound)

        {

            //这里操作其他动作

            

            return false;

        }

    return YES;

}

 

2. oc传参数给js  (触发按钮点击事件里面操作)

 

<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo } p.p2 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; min-height: 16.0px } p.p3 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo; color: #3d1d81 } span.s1 { } span.s2 { color: #bb2ca2 } span.s3 { color: #703daa } span.s4 { color: #4f8187 } span.s5 { color: #d12f1b } span.s6 { color: #3d1d81 } span.s7 { color: #272ad8 } span.s8 { color: #000000 }</style>

- (void)deleteBtnClick:(UIButton *)sender 

{

    //deleAll是js的方法

    JSValue * function = context[@"deleAll"];

  //delete是要传递给js的参数

    JSValue *result = [function callWithArguments:@[@"delete"]];

    

   //让js用一个弹出框弹出delete

}

 

目前用到这些  自己总结的  不对的请大家多多指教 

<style>p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 14.0px Menlo } span.s1 { } span.s2 { color: #703daa }</style>

OC 和 js 交互