zoukankan      html  css  js  c++  java
  • JS与OC交互,JS中调用OC方法(获取JSContext的方式)

    最近用到JS和OC原生方法调用的问题,查了许多资料都语焉不详,自己记录一下吧,如果有误欢迎联系我指出。

    JS中调用OC方法有三种方式:

    1.通过获取JSContext的方式直接调用OC方法
    2.通过继承自JSExport的方式调用delegate中的方法
    3.截取URL的方式(此种方式资料很多,就不写了)

    先上OC代码

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

        // 设置javaScriptContext上下文

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

    // 方法一
        __weak typeof(self) weakSelf = self;
        self.jsContext[@"getMessage"] = ^(){
            return [weakSelf blockCallMessage];
        };
    
        // 方法二
        self.jsContext[@"JavaScriptInterface"] = self;
    }
    
    - (NSString *)blockCallMessage {
    return @"call via block"; } #pragma mark - JSCallDelegate // 提供给JS调用的方法 - (NSString *)tipMessage {
    return @"call via delegate"; }

    HTML代码

    <html>
    <head>
    </head>
    <body>
        <script>
            function buttonClick1()
            {
                // 方法一
                 var token = getMessage();
    
                alert(token)
            }
            function buttonClick2()
            {
                // 方法二
                var token = JavaScriptInterface.tipMessage();
            
                alert(token)
            }
            </script>
        <button id="abc" onclick="buttonClick1()">function 1</button>
        <button id="abcd" onclick="buttonClick2()">function 2</button>
    </body>
    </html>

    方法一中的jsContext[@"getMessage"]需要和JS中调用的方法名一致,既JS中需要直接调用getMessage(),而jsContext[@"getMessage"]则赋值为一个block,这个block中调用的方法就是JS中调用getMessage()就是执行这个block;

    方法二中的jsContext[@"JavaScriptInterface"] = self其中的JavaScriptInterface可以随便命名,保持JS中和该命名保持一致即可,JS中通过JavaScriptInterface来调用继承自JSExport的delegate中的方法,即JavaScriptInterface.tipMessage()

  • 相关阅读:
    被隐藏的文件更改为可见
    Selenium WebDriver多层表单切换
    for循环
    Java课程设计二次大作业
    Java-DAO模式代码阅读及应用
    编辑器、编译器、文件、IDE等常见概念辨析
    树、二叉树和查找等知识点的总结
    二叉树的实现
    二叉树顺序结构和链式结构的相互转换
    使用k-近邻算法改进约会网站的配对效果
  • 原文地址:https://www.cnblogs.com/xuzb/p/9018661.html
Copyright © 2011-2022 走看看