H5与App使用WebViewJavascriptBridge进行交互

简介: H5与App使用WebViewJavascriptBridge进行交互

JS端操作:

1.引入bridgejs,将和原生交互的方法挂载到全局

// main.js
import Vue from 'vue'
import App from './App.vue'
import router from './router'
import store from './store'
// 引入bridgejs
import Bridge from './util/bridge.js'
// 将和native交互的方法挂载到全局
Vue.prototype.$bridge = Bridge
Vue.config.productionTip = false
new Vue({
  router,
  store,
  render: h => h(App)
}).$mount('#app')


2.复制并粘贴setupWebViewJavascriptBridge到您的 JS 中:

function setupWebViewJavascriptBridge(callback) {
    if (window.WebViewJavascriptBridge) { return callback(WebViewJavascriptBridge); }
    if (window.WVJBCallbacks) { return window.WVJBCallbacks.push(callback); }
    window.WVJBCallbacks = [callback];
    var WVJBIframe = document.createElement('iframe');
    WVJBIframe.style.display = 'none';
    WVJBIframe.src = 'https://__bridge_loaded__';
    document.documentElement.appendChild(WVJBIframe);
    setTimeout(function() { document.documentElement.removeChild(WVJBIframe) }, 0)
}


3.调用setupWebViewJavascriptBridge然后使用桥来注册处理程序并调用方法:

setupWebViewJavascriptBridge(function(bridge) {
    //注册桥(App调用JS的方法给JS传递数据用这个方法)
    //第一个参数是App调用JS的函数名字,data为接收到来自App的数据,responseCallback是回传数据给App的方法
    bridge.registerHandler('JS Echo', function(data, responseCallback) {
        responseCallback(data)
    })
    //调用app内的方法(JS调用App的方法给App传递数据用这个方法)
    //第一个参数是JS调用App的函数名字,第二个参数是JS传递给App的数据,responseData是App回传给JS的数据
    bridge.callHandler('App Echo', {'key':'value'}, function responseCallback(responseData) {
    })
})


iOS端操作:

1.导入头文件并声明一个变量:

#import "WebViewJavascriptBridge.h"

@property WebViewJavascriptBridge* bridge;


2.使用 WKWebView、UIWebView (iOS) 或 WebView (OSX) 实例化 WebViewJavascriptBridge:

self.bridge = [WebViewJavascriptBridge bridgeForWebView:webView];


3.在 ObjC 中注册一个 handler:(JS调用ObjC的方法给ObjC传递数据用这个方法)

//第一个参数是JS调用App的函数名字,data为JS传递给App的数据,responseCallback为App回传数据给JS的方法
[self.bridge registerHandler:@"ObjC Echo" handler:^(id data, WVJBResponseCallback responseCallback) {
    responseCallback(data);
}];


4.调用一个 JS handler:(ObjC调用JS的方法给JS传递数据用这个方法)

//第一个参数是App调用JS的函数名字,data为App传递给JS的数据,responseData为JS回传给App的数据
[self.bridge callHandler:@"JS Echo" data:nil responseCallback:^(id responseData) {
}];


安卓端操作:

1.Android Studio 导包

repositories {
    // ...
    maven { url "https://jitpack.io" }
}
dependencies {
    compile 'com.github.lzyzsd:jsbridge:1.0.4'
}


2.在布局文件中添加

<com.github.lzyzsd.jsbridge.BridgeWebView
    android:id="@+id/wv_web_view"
    android:layout_width="match_parent"
    android:layout_height="match_parent" />


3.在 Java 中注册一个 handler:(JS调用Java的方法给Java传递数据用这个方法)

//第一个参数是JS调用App的函数名字,data为JS传递给App的数据,onCallBack为App回传数据给JS的方法
mBridgeWebView.registerHandler("submitFromWeb", new BridgeHandler() {
    @Override
     public void handler(String data, CallBackFunction function) {
     function.onCallBack("指定Handler收到Web发来的数据,回传数据给你");
     }
});


4.调用一个 JS handler:(Java调用JS的方法给JS传递数据用这个方法)

//第一个参数是App调用JS的函数名字,第二个参数是App传递给JS的数据,data为JS回传给App的数据
mBridgeWebView.callHandler("functionInJs","发送数据给web指定接收",new CallBackFunction(){
     @Override
     public void onCallBack(String data) {
     }
});


目录
相关文章
|
6月前
|
移动开发 前端开发 Android开发
【02】建立各项目录和页面标准化产品-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
【02】建立各项目录和页面标准化产品-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
1055 12
【02】建立各项目录和页面标准化产品-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
|
6月前
|
移动开发 JavaScript 应用服务中间件
【06】优化完善落地页样式内容-精度优化-vue加vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
【06】优化完善落地页样式内容-精度优化-vue加vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
837 5
【06】优化完善落地页样式内容-精度优化-vue加vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
|
6月前
|
移动开发 Rust JavaScript
【01】首页建立-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
【01】首页建立-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
996 4
【01】首页建立-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
|
6月前
|
移动开发 Android开发
【03】建立隐私关于等相关页面和内容-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
【03】建立隐私关于等相关页面和内容-vue+vite开发实战-做一个非常漂亮的APP下载落地页-支持PC和H5自适应提供安卓苹果鸿蒙下载和网页端访问-优雅草卓伊凡
311 0
|
11月前
|
存储 人工智能 移动开发
uni-app+vue3接入deepseek-v3搭建跨端ai流式(小程序+app+h5)
基于Uniapp+Vue3+Markdown接入DeepSeek-V3聊天大模型,支持编译到H5+小程序+App端。实现流式输出、支持亮色/暗黑主题、代码高亮、会话本地存储等功能。
1984 12
|
XML 移动开发 开发者
京东商品详情数据接口(H5、APP 端)
京东商品详情数据接口是为H5和APP开发者提供的工具,支持获取商品名称、价格、库存、销量、评价、图片等详细信息,优化应用功能。接口返回JSON或XML格式数据,方便解析处理。适用于电商导购、社交媒体分享、活动推广、价格监控等场景,提升用户体验和购物决策效率。示例代码展示了使用Python发送GET请求的方法。
|
移动开发 JSON API
1688 商品详情数据接口(H5、APP 端)
1688商品详情数据接口是1688平台提供的数据交互通道,支持H5和APP端,提供商品的全面信息(如标题、价格、库存、销量等),并实时更新。开发者可通过HTTP/HTTPS协议调用接口,使用GET或POST方法获取数据。示例代码展示了如何用Python请求该接口,需替换API密钥和商品ID。
|
移动开发 小程序 前端开发
使用php开发圈子系统特点,如何获取圈子系统源码,社交圈子运营以及圈子系统的功能特点,圈子系统,允许二开,免费源码,APP 小程序 H5
开发一个圈子系统(也称为社交网络或社群系统)可以是一个复杂但非常有趣的项目。以下是一些关键特点和步骤,帮助你理解如何开发、获取源码以及运营一个圈子系统。
642 4
|
缓存 移动开发 小程序
uni-vue3-wetrip自创跨三端(H5+小程序+App)酒店预订app系统模板
vue3-uni-wetrip原创基于vite5+vue3+uniapp+pinia2+uni-ui等技术开发的仿去哪儿/携程预约酒店客房app系统。实现首页酒店展示、预订搜索、列表/详情、订单、聊天消息、我的等模块。支持编译H5+小程序+App端。
540 8
|
移动开发 小程序
thinkphp+uniapp开发的多端商城系统源码/H5/小程序/APP支持DIY模板直播分销
thinkphp+uniapp开发的多端商城系统源码/H5/小程序/APP支持DIY模板直播分销
696 0

热门文章

最新文章