jsbridge实战2:Swift和h5的jsbridge通信

\[toc\]

demo1: 文本通信

h5 -> app

思路:

  • h5 全局属性上挂一个变量
  • app 接收这个变量的内容
  • 关键API: navigation代理 + navigationAction.request.url?.absoluteString
js 复制代码
// 这个变量挂载在 request 的 url 上 ,在浏览器实际无法运行,因此不会影响到页面本身
window.location.href="test://hellowolrd"
// app 接收这个变量
navigationAction.request.url?.absoluteString
swift 复制代码
import UIKit
import WebKit
class ViewController: UIViewController, WKUIDelegate {
    var webView: WKWebView!
    override func loadView() {
        let webConfiguration = WKWebViewConfiguration()
        webView = WKWebView(frame: .zero, configuration: webConfiguration)
        // 【1】设置自己为webview的代理
        webView.uiDelegate = self
        webView.navigationDelegate = self
        view = webView        
    }
    override func viewDidLoad() {
        super.viewDidLoad()
        let myURL = URL(string:"http://localhost:5173/") // ok
        let myRequest = URLRequest(url: myURL!)
        webView.load(myRequest)
        print("viewDidLoad...")
    }
}
extension ViewController: WKNavigationDelegate {
    //【2】通过 navigationAction.request.url?.absoluteString  获取 h5 传递的数据
    func webView(_ webView: WKWebView, decidePolicyFor navigationAction: WKNavigationAction, decisionHandler: @escaping (WKNavigationActionPolicy) -> Void) {
        print("webView decidePolicyFor ...")
        print(navigationAction.request.url?.absoluteString)
        decisionHandler(.allow)
    }
}

app -> h5

思路

  • app调用js语法,将app的数据通过 html dom结构或者js方法 传递给h5
  • 关键API:webView.evaluateJavaScript
html 复制代码
<!-- h5页面 -->
<div id="someElement1">test data1</div>
<div id="someElement2"></div>
<script>
    window.getText=function(data){
        const reuslt = 'test data2:'+data;
        document.getElementById('someElement2').innerText = reuslt;
        return reuslt; 
    }
</script>
swift 复制代码
// app swift
func webView(_ webView: WKWebView, didFinish navigation: WKNavigation!) {
    print("webView didFinish 页面加载完成之后调用...")
    webView.evaluateJavaScript("document.getElementById('someElement1').innerText='test data1: app'") {
        (result, error) in
        if let result = result {
            print("someElement result: \(result)")
        }
        if let error = error {
            print("someElement error: \(error)")
        }
    }
    webView.evaluateJavaScript("window.getText('app')") { (result, error) in
        if let result = result {
            print("getText result: \(result)")
        }
        if let error = error {
            print("getText error: \(error)")
        }
    }
}

demo2: h5通过app调用相机和扫描二维码

思路

  • 原生app具备调用相机和扫描二维码的能力
  • h5通过jsbridge通知app-》app执行拍照和扫描动作-》将结果返回h5
相关推荐
蹦蹦跳跳真可爱589几秒前
Python----OpenCV(几何变换--图像平移、图像旋转、放射变换、图像缩放、透视变换)
开发语言·人工智能·python·opencv·计算机视觉
骁的小小站5 分钟前
HDLBits刷题笔记和一些拓展知识(十一)
开发语言·经验分享·笔记·其他·fpga开发
Jtti6 分钟前
如何准确查看服务器网络的利用率?
开发语言·php
形影相吊7 分钟前
iOS防截屏实战
ios
人生在勤,不索何获-白大侠12 分钟前
day17——Java集合进阶(Collections、Map)
java·开发语言
吴Wu涛涛涛涛涛Tao14 分钟前
Flutter 弹窗解析:从系统 Dialog 到完全自定义
flutter·ios
程序员小羊!24 分钟前
Java教程:JavaWeb ---MySQL高级
java·开发语言·mysql
m0_7231402331 分钟前
Python训练营-Day49
开发语言·python
一洽客服系统1 小时前
网页嵌入与接入功能说明
开发语言·前端·javascript
zhangfeng11331 小时前
python 数据分析 单细胞测序数据分析 相关的图表,常见于肿瘤免疫微环境、细胞亚群功能研究 ,各图表类型及逻辑关系如下
开发语言·python·数据分析·医学