niapp开发的 H5 被app嵌套,H5调用ios和安卓方法

封装方法

javascript 复制代码
export function appSkipH5(params = {}, action) {
	try {
		// 1. 环境判断:区分安卓/iOS/非APP环境
		const ua = navigator.userAgent;
		const isAndroid = /Android|Adr/i.test(ua); // 安卓环境
		const isIOS = /iPhone|iPad|iPod|iOS/i.test(ua); // iOS环境

		if (!isAndroid && !isIOS) {
			uni.showToast({
				title: '仅支持在APP内跳转',
				icon: 'none'
			});
			return;
		}

		const paramsStr = JSON.stringify(params);
		// 2. 根据action类型执行不同的跳转逻辑
//安卓: WebAndroid是安卓自定义的
//IOS: window.webkit.messageHandlers.XXXX.postMessage() XXXX 是IOS自定函数;
		console.log(action, paramsStr, "paramsStr");
		switch (action) {

			case 'goToGoodsDetail': // 商品详情页 IOS和安卓调用的方法goToGoodsDetail
				// 安卓端调用(传递参数JSON字符串)
				if (isAndroid) {
					WebAndroid.goToGoodsDetail(paramsStr);
				}

				// iOS端调用(直接传递参数对象)
				if (isIOS) {
					window.webkit.messageHandlers.goToGoodsDetail.postMessage(paramsStr);
				}
				break;

			case 'finishAct': // 关闭当前界面--IOS和安卓调用的方法finishAct
				// 安卓端调用(传递参数JSON字符串)
				if (isAndroid) {
					WebAndroid.finishAct();
				}

				// iOS端调用(直接传递参数对象)
				if (isIOS) {
					window.webkit.messageHandlers.finishAct.postMessage();
				}
				break;

			case 'goToMain': // 跳转到首页IOS和安卓调用的方法goToMain
				// 安卓端调用(传递参数JSON字符串)
				if (isAndroid) {
					WebAndroid.goToMain();
				}

				// iOS端调用(直接传递参数对象)
				if (isIOS) {
					window.webkit.messageHandlers.goToMain.postMessage();
				}
				break;
		}

	} catch (e) {
		console.error('跳转失败:', e);
		uni.showToast({
			title: '跳转失败,请重试',
			icon: 'none'
		});
	}
}

页面引入

javascript 复制代码
	import {
		appSkipH5
	} from "@/utils/patch.js"

appSkipH5(jumpParams, "goToGoodsDetail")
相关推荐
Doro再努力2 小时前
【Linux操作系统10】Makefile深度解析:从依赖推导到有效编译
android·linux·运维·服务器·编辑器·vim
Daniel李华2 小时前
echarts使用案例
android·javascript·echarts
做人不要太理性3 小时前
CANN Runtime 运行时组件深度解析:任务调度机制、存储管理策略与维测体系构建逻辑
android·运维·魔珐星云
我命由我123453 小时前
Android 广播 - 静态注册与动态注册对广播接收器实例创建的影响
android·java·开发语言·java-ee·android studio·android-studio·android runtime
朗迹 - 张伟4 小时前
Tauri2 导出 Android 详细教程
android
lpruoyu4 小时前
【Android第一行代码学习笔记】Android架构_四大组件_权限_持久化_通知_异步_服务
android·笔记·学习
独自破碎E5 小时前
【BISHI15】小红的夹吃棋
android·java·开发语言
李堇8 小时前
android滚动列表VerticalRollingTextView
android·java
lxysbly10 小时前
n64模拟器安卓版带金手指2026
android
游戏开发爱好者813 小时前
日常开发与测试的 App 测试方法、查看设备状态、实时日志、应用数据
android·ios·小程序·https·uni-app·iphone·webview