h5和app原生通信的方法,什么是jsBridge,jsBridge 原理和步骤

2024-02-29 04:28

本文主要是介绍h5和app原生通信的方法,什么是jsBridge,jsBridge 原理和步骤,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

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

  1. url scheme
  2. jsBridge
    1. 也就是 javascript interface
    2. 原生应用通过注入 JavaScript 接口到 WebView 中,让 H5 页面可以调用原生方法,从而实现双向通信【本质还是利用了 android webview 提供了注入的方法】
  3. WebSocket
  4. Hybrid 框架的通信机制
  5. LocalStorage 或者 IndexedDB

什么是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 访问

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

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

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

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

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

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

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

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

完整代码如下,由chatgpt生成

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

这篇关于h5和app原生通信的方法,什么是jsBridge,jsBridge 原理和步骤的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/757573

相关文章

Conda与Python venv虚拟环境的区别与使用方法详解

《Conda与Pythonvenv虚拟环境的区别与使用方法详解》随着Python社区的成长,虚拟环境的概念和技术也在不断发展,:本文主要介绍Conda与Pythonvenv虚拟环境的区别与使用... 目录前言一、Conda 与 python venv 的核心区别1. Conda 的特点2. Python v

Spring Boot中WebSocket常用使用方法详解

《SpringBoot中WebSocket常用使用方法详解》本文从WebSocket的基础概念出发,详细介绍了SpringBoot集成WebSocket的步骤,并重点讲解了常用的使用方法,包括简单消... 目录一、WebSocket基础概念1.1 什么是WebSocket1.2 WebSocket与HTTP

SQL Server配置管理器无法打开的四种解决方法

《SQLServer配置管理器无法打开的四种解决方法》本文总结了SQLServer配置管理器无法打开的四种解决方法,文中通过图文示例介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的... 目录方法一:桌面图标进入方法二:运行窗口进入检查版本号对照表php方法三:查找文件路径方法四:检查 S

MyBatis-Plus 中 nested() 与 and() 方法详解(最佳实践场景)

《MyBatis-Plus中nested()与and()方法详解(最佳实践场景)》在MyBatis-Plus的条件构造器中,nested()和and()都是用于构建复杂查询条件的关键方法,但... 目录MyBATis-Plus 中nested()与and()方法详解一、核心区别对比二、方法详解1.and()

golang中reflect包的常用方法

《golang中reflect包的常用方法》Go反射reflect包提供类型和值方法,用于获取类型信息、访问字段、调用方法等,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值... 目录reflect包方法总结类型 (Type) 方法值 (Value) 方法reflect包方法总结

IDEA中新建/切换Git分支的实现步骤

《IDEA中新建/切换Git分支的实现步骤》本文主要介绍了IDEA中新建/切换Git分支的实现步骤,通过菜单创建新分支并选择是否切换,创建后在Git详情或右键Checkout中切换分支,感兴趣的可以了... 前提:项目已被Git托管1、点击上方栏Git->NewBrancjsh...2、输入新的分支的

C# 比较两个list 之间元素差异的常用方法

《C#比较两个list之间元素差异的常用方法》:本文主要介绍C#比较两个list之间元素差异,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. 使用Except方法2. 使用Except的逆操作3. 使用LINQ的Join,GroupJoin

MySQL查询JSON数组字段包含特定字符串的方法

《MySQL查询JSON数组字段包含特定字符串的方法》在MySQL数据库中,当某个字段存储的是JSON数组,需要查询数组中包含特定字符串的记录时传统的LIKE语句无法直接使用,下面小编就为大家介绍两种... 目录问题背景解决方案对比1. 精确匹配方案(推荐)2. 模糊匹配方案参数化查询示例使用场景建议性能优

关于集合与数组转换实现方法

《关于集合与数组转换实现方法》:本文主要介绍关于集合与数组转换实现方法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录1、Arrays.asList()1.1、方法作用1.2、内部实现1.3、修改元素的影响1.4、注意事项2、list.toArray()2.1、方

从原理到实战深入理解Java 断言assert

《从原理到实战深入理解Java断言assert》本文深入解析Java断言机制,涵盖语法、工作原理、启用方式及与异常的区别,推荐用于开发阶段的条件检查与状态验证,并强调生产环境应使用参数验证工具类替代... 目录深入理解 Java 断言(assert):从原理到实战引言:为什么需要断言?一、断言基础1.1 语