javascript - 在 javascript 中调用原生的 swift 函数

标签 javascript ios swift webkit

很抱歉,如果这个问题已经被问到,但我能找到的所有答案都是针对复杂的解决方案。

我有一个viewController,也就是webView。我将 WKWebView 添加到 WebKit 库的 View 中,并打开了简单的 url。在我的 ViewController 中,我有一个名为 showAd 的 native 函数。 当用户按下用 javascript 实现的按钮时,它会显示调用 showRewardsAd。我将断点设置到 userContentController,但是,它永远不会到达那里。

func showAd(){
   print("invoked")
}
extension WFWebViewController: WKScriptMessageHandler{
    func userContentController(_ userContentController: WKUserContentController, didReceive message: WKScriptMessage) {
        if message.name == "showRewardsAd"{
            self.showRewards()
            webView.evaluateJavaScript("test", completionHandler: nil)
        }
    }
}

我的目标是简单地允许从 javascript 部分调用此函数。据我所知,如果我想在 swift 中调用 javascript 函数,我只需要说:

 webview.addJavascriptInterface('javascript: function_name();')

但是,就我而言,我想以相反的顺序进行。在 Javascript 代码中调用 swift 函数。

最佳答案

您需要将您的用户脚本注入(inject)到 webView 中,以便您可以在发布时收听 JavaScript 的消息。

首先,您需要初始化 webView 的配置和首选项,以允许 javaScript:

let config = WKWebViewConfiguration()
let preferences = WKPreferences()
preferences.javaScriptEnabled = true
config.preferences = preferences

现在,您需要注入(inject)脚本来监听来自 webView 的点击事件:

let userController = WKUserContentController()
let javaScript = "showRewardsAd = function() {\n" + "window.webkit.messageHandlers.adClicked.postMessage(); }"
let script = WKUserScript(source: javaScript, injectionTime: .atDocumentEnd, forMainFrameOnly: false)
userController.addUserScript(script)
userController.add(self, name: "adClicked")
config.userContentController = userController

现在使用上面的配置实例化您的 webView:

self.webView = WKWebView(frame: .zero, configuration: config)

现在,您的 WKScriptMessageHandler 协议(protocol)已正确实现:

extension WFWebViewController: WKScriptMessageHandler{
    func userContentController(_ userContentController: WKUserContentController, didReceive message: WKScriptMessage) {
        if message.name == "showRewardsAd"{
            self.showRewards()
            print("Ad is being shown.")
        }
    }
}

我希望这对你有用。我假设 showRewardsAd 是在您正在访问的网站上的 JavaScript 中实现的。

关于javascript - 在 javascript 中调用原生的 swift 函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/64383269/

相关文章:

javascript - 右键单击 ui-grid 选择

ios - CCLabelTTF 在 iOS 6.1 中不起作用

uitableview - 无法在 Swift 中访问自定义 tableviewcell 按钮属性

ios - 水平呈现 avplayer

javascript - 基于屏幕调整大小(而不是页面刷新)进行检测

javascript - 钛拾取器滚动首次出现滞后

javascript - 为页面速度删除元素 JS 与 CSS

ios - 我可以通过 UISearchController 以编程方式复制 UIStatusBar 上的点击吗?

ios - 安排应用程序在特定日期/时间启动/进入前台

swift - 原始类型 'Bool' 不能用任何文字表达