关于uniapp的app和uniapp的H5互相通讯实现H5调取app扫码再传入H5(app内嵌H5,webView)

本文详细描述了如何在H5页面通过uni-app的webview进行双向通信,包括H5向app传递数据(如扫码结果)以及app向H5回传值并实现页面跳转的过程。

一.h5传值给app

1,在h5项目的mian.js中引入

// #ifdef H5
import '@/common/webview_sdk.js'
// #endif

//此处需要注意的是如果项目本身要打包成app,记得使用条件编译,否则在app运行时本次引入会报错

2.h5页面给app传值部分

otherAppMethod(e){
                uni.webView.postMessage({
                    data:{
                        action:e
                    }
                })
            },

### UniApp WebView 内嵌 H5 页面显示获取权限说明的方法 在 UniApp 中,`<web-view>` 组件用于加载外部网页或本地 HTML 文件。要实现 WebView 内嵌 H5 页面并显示获取权限的说明,可以通过 JavaScript Bridge 进行双向通信来处理权限请求。 #### 1. 在 H5 页面中发起权限请求 假设 H5 页面需要访问相机权限来进行功能,则可以在 `index.vue` 的 mounted 生命周期钩子中设置事件监听器: ```javascript mounted() { document.addEventListener("getAppMsg", (e) => { console.log('getAppMsg', e.detail.code); if(e.detail.code === 'requestPermission') { alert('应用正在请求相机权限'); } }, false); }, methods: { requestCameraPermission() { uni.webView.postMessage({ data: { action: 'requestPermission', permissionType: 'camera' } }); } } ``` 这段代会在接收到特定消息时弹出提示框告知用户应用程序正尝试获取相应权限[^1]。 #### 2. 处理来自 H5 页面的消息并在原生层面上申请权限 对于 Android 或 iOS 平台上的实际权限管理操作需由 Native 层面完成。因此,在 App 端也需要编写逻辑响应这些来自 Web 视图内的调用。这通常涉及到使用插件或者直接调用平台 API 请求权限。 例如,在 main.js 中可以这样写: ```javascript import webView from './static/js/uni.webview.1.5.2.js'; // 监听来自 webview 的消息 webView.onMessage((message) => { const {action, permissionType} = message.data; if(action === 'requestPermission'){ switch(permissionType){ case 'camera': // 调用 native 方法请求相机权限 plus.runtime.requestPermissions(['android.permission.CAMERA'], function(){ webView.postMessage({data:{result:'granted'}}); },function(error){ webView.postMessage({data:{result:'denied'}}); }); break; default: console.error(`Unknown permission type ${permissionType}`); } } }) ``` 这里展示了如何捕获到来自 H5 页面的消息,并根据不同的权限类型采取行动。如果成功获得授权,则返回给 H5 成功的结果;反之亦然[^5]。 #### 3. 控制 WebView 加载行为与样式调整 为了避免初次加载时出现白屏现象以及更好地适配不同设备尺寸下的展示效果,建议按照官方指南配置 `<web-view>` 标签属性 CSS 样式表[^3]。 另外还可以利用 `prefetchWebview()` 函数提前加载目标 URL 所指向的内容到缓存区里去,从而提高用户体验感[^4]。
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值