当前位置:   article > 正文

h5和app原生通信的方法,什么是jsBridge,jsBridge 原理和步骤_h5与客户端交互的js叫啥

h5与客户端交互的js叫啥

H5 和 App 原生应用之间通信的方法

  1. url scheme
  2. url 参数
  3. jsBridge
    1. 也就是 javascript interface
    2. 原生应用通过注入 JavaScript 接口到 WebView 中,让 H5 页面可以调用原生方法,从而实现双向通信【本质还是利用了 android webview 提供了注入的方法】【简称API注入
  4. WebSocket
  5. postMessage【没错这个也可以】
  6. Hybrid 框架的通信机制
  7. LocalStorage 或者 IndexedDB、
  8. 数据库等

什么是 jsBridge

JSBridge 是一种机制,用于在 WebView 中的 JavaScript 和原生应用之间进行通信。它允许 JavaScript 代码调用原生应用的方法,并且允许原生应用调用 JavaScript 中的方法,实现了两者之间的双向通信。

jsBridge 实现的详细步骤:

  1. 原生应用给 webview 注册接口:原生应用在加载 WebView 时,会提供一些接口供 JavaScript 调用。

    1. 调用 andorid webview 提供的原生方法,webview.addJavascriptInterface 给 webview注册一个接口,名字叫 NativeInterface【可以自定义这个名字,和前端对好就行】

    2. addJavascriptInterface 有两个参数

      1. Object obj:要添加的Java对象,它可以是Java代码中的任何对象(如活动,服务等)。

      2. String interfaceName:该Java对象在JavaScript代码中使用的名称【我们这里叫NativeInterface】【可以自定义这个名字,和前端对好就行】。

      3. NativeInterface 会被挂载到 js 的全局作用域,webview中前端可以使用 window.NativeInterface 访问

      1. // 注册 JSBridge 接口,命名为 NativeInterface
      2. // AndroidNativeInterface 这个也要自己定义
      3. // AndroidNativeInterface里面通常有一个 方法,供js调用
      4. webView.addJavascriptInterface(new AndroidNativeInterface(), "NativeInterface");
      5. class AndroidNativeInterface {
      6. // 接收来自 H5 页面的消息,并在原生应用中处理
      7. @JavascriptInterface
      8. public void handleMessage(String message) {
      9. // 处理来自 H5 页面的消息
      10. // 这里可以执行一些原生操作,或者将数据传递给其他组件
      11. // 为了简单起见,我们只是打印接收到的消息
      12. System.out.println("Received message from H5: " + message);
      13. // 在这里可以执行一些原生操作,例如弹出一个 Toast
      14. // Toast.makeText(MainActivity.this, message, Toast.LENGTH_SHORT).show();
      15. // 接收到消息后,可以调用 H5 页面中定义的接口来传递数据给 H5 页面
      16. // webView.evaluateJavascript("JSBridge.receiveMessageFromNative('" + message + "')", null);
      17. }
      18. }
  2. Javascript 封装 jsBridge对象

    1. 通常是包括【给原生应用发送消息】和【接收原生应用发来的消息】

      1. var JSBridge = {
      2. // 调用原生应用的方法,参数为要传递给原生方法的数据
      3. callNativeMethod: function(data) {
      4. // 调用原生方法,并传递数据
      5. window.NativeInterface.handleMessage(data);
      6. },
      7. // 接收原生应用传递的数据,并处理
      8. receiveMessageFromNative: function(data) {
      9. // 处理接收到的数据
      10. onsole.log("Received data from native: " + data);
      11. }
      12. };
    2. 【原生应用】可以调用下面的 JSBridge.receiveMessageFromNative 给 webview 传递数据,具体语法如下

    3. webView.evaluateJavascript("JSBridge.receiveMessageFromNative('" + message + "')", null);
    4. webView.evaluateJavascript 也是 andorid webview 提供的原生方法,参数是我们 js 里面声明的 JSBridge 全局对象【JSBridge这个名字可以自定义,但是原生应用和 js 要统一】

  3. js 给【原生应用】发送消息

    1. 调用完这一句,就是调用原生应用的 handleMessage,handleMessage里面有响应方法
      1. //给原生应用发送消息, 传递对象数据 {name: 'test'}
      2. JSBridge.callNativeMethod({name: 'test'})
  4. 原生应用 给 js 发送消息

    1. 就是在 handleMessage 里面的这条语句, JSBridge.receiveMessageFromNative 给webview传递数据

    2. webView.evaluateJavascript("JSBridge.receiveMessageFromNative('" + message + "')", null);

完整代码如下,由chatgpt生成

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <meta name="viewport" content="width=device-width, initial-scale=1.0">
  6. <title>JSBridge Demo</title>
  7. <script>
  8. // 定义 JSBridge 对象,用于与原生应用通信
  9. var JSBridge = {
  10. // 调用原生应用的方法,参数为要传递给原生方法的数据
  11. callNativeMethod: function(data) {
  12. // 调用原生方法,并传递数据
  13. window.NativeInterface.handleMessage(data);
  14. },
  15. // 接收原生应用传递的数据,并处理
  16. receiveMessageFromNative: function(data) {
  17. // 处理接收到的数据
  18. console.log("Received data from native: " + data);
  19. }
  20. };
  21. </script>
  22. </head>
  23. <body>
  24. <button onclick="JSBridge.callNativeMethod('Hello from H5!')">Call Native Method</button>
  25. </body>
  26. </html>
  1. import android.os.Bundle;
  2. import android.webkit.JavascriptInterface;
  3. import android.webkit.WebChromeClient;
  4. import android.webkit.WebView;
  5. import android.webkit.WebViewClient;
  6. import androidx.appcompat.app.AppCompatActivity;
  7. public class MainActivity extends AppCompatActivity {
  8. @Override
  9. protected void onCreate(Bundle savedInstanceState) {
  10. super.onCreate(savedInstanceState);
  11. setContentView(R.layout.activity_main);
  12. WebView webView = findViewById(R.id.webview);
  13. webView.setWebViewClient(new WebViewClient());
  14. webView.setWebChromeClient(new WebChromeClient());
  15. webView.getSettings().setJavaScriptEnabled(true);
  16. // 注册 JSBridge 接口,命名为 AndroidNativeInterface
  17. webView.addJavascriptInterface(new AndroidNativeInterface(), "NativeInterface");
  18. // 加载 H5 页面
  19. webView.loadUrl("file:///android_asset/index.html");
  20. }
  21. // 自定义的 Android 原生接口
  22. class AndroidNativeInterface {
  23. // 接收来自 H5 页面的消息,并在原生应用中处理
  24. @JavascriptInterface
  25. public void handleMessage(String message) {
  26. // 处理来自 H5 页面的消息
  27. // 这里可以执行一些原生操作,或者将数据传递给其他组件
  28. // 为了简单起见,我们只是打印接收到的消息
  29. System.out.println("Received message from H5: " + message);
  30. // 在这里可以执行一些原生操作,例如弹出一个 Toast
  31. // Toast.makeText(MainActivity.this, message, Toast.LENGTH_SHORT).show();
  32. // 接收到消息后,可以调用 H5 页面中定义的接口来传递数据给 H5 页面
  33. // webView.evaluateJavascript("JSBridge.receiveMessageFromNative('" + message + "')", null);
  34. }
  35. }
  36. }

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/AllinToyou/article/detail/710366
推荐阅读
相关标签
  

闽ICP备14008679号