本文最后更新于:2023年11月7日 下午
背景
这个标题就已经够抽象了吧
本来用微信小程序的web-view去嵌套h5已经因为微信的种种限制(微信不希望你把微信小程序当做一个浏览器来用,它就是不想担责)导致微信登录、文件下载等种种微信特色问题已经很烦了,结果我们这有个场景是用uniapp开发出h5的页面,然后再用微信小程序的web-view去嵌套这个uniapp生成的h5页面……
本次下载场景的情况也是在文件下载的时候,安卓手机点击没反应,ios能打开文件但是都是乱码
解决方案
出现的问题跟这位老哥一模一样:
uniapp微信小程序使用webview嵌套h5的文件下载问题
他的解决方案是没错的但是遗漏了一些要点,这里结合在微信小程序官方文档以及另外一位知乎老哥较为完整的描述进行总结
一、思路
通过判断当前的设备环境来进行不同的操作,如果判断是微信小程序则在h5中跳转到小程序的特定页面,并且将文件资源的URL传递过去。之后在小程序中调用微信的下载文件或者保存文件API
二、引入依赖
这一步很关键,但是CSDN的老哥遗漏没讲
如果是普通h5,那么引入js:
1
| <script type="text/javascript" src="https://res.wx.qq.com/open/js/jweixin-1.6.0.js"></script>
|
如果是uniapp(本质上是Vue)或者Vue项目,需要安装依赖并引入:
1
| npm install weixin-webview-jssdk
|
1
| import wx from "weixin-webview-jssdk";
|
三、H5端代码
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54
| var ua = window.navigator.userAgent.toLowerCase(); if (ua.match(/micromessenger/i) == 'micromessenger') { uni.showModal({ title: '提示', content: '是微信客户端:' + ua, success: function (res) { if (res.confirm) { var fileDownPath = 'https://www.baidu.com/img/flexible/logo/pc/result.png'; wx.miniProgram.navigateTo({ url: `/pages/file-upload/file-upload?url=${encodeURIComponent(fileDownPath)}` }) }else { } } }) } else { uni.showModal({ title: '提示', content: '不是微信客户端:' + ua, success: function (res) { if (res.confirm) { }else { } } }) uni.downloadFile({ url: this.baseURL + url, success: (res) => { var filePath = res.tempFilePath; uni.openDocument({ filePath: encodeURI(filePath), showMenu: true, fileType: fileType, success: (res) => { console.log('打开文档成功'); }, fail(err) { console.log('小程序', err); } }); } }); }
|
四、微信小程序端代码
- tip:每个页面只能有一个 web-view,web-view 会自动铺满整个页面,并覆盖其他组件。
- tip:web-view 网页与小程序之间不支持除 JSSDK 提供的接口之外的通信。
- tip:在 iOS 中,若存在 JSSDK 接口调用无响应的情况,可在 web-view 的 src 后面加个#wechat_redirect解决。
- tip:避免在链接中带有中文字符,在 iOS 中会有打开白屏的问题,建议加一下 encodeURIComponent
新建一个下载用的页面
获取参数URL调用微信小程序api去下载就行
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122 123 124 125 126 127 128 129 130 131 132 133 134 135 136 137 138 139 140
| Page({
data: { url: '' },
onLoad: function (options) { let that = this let url = decodeURIComponent(options.url) console.log(url); this.setData({ url: url }) wx.showLoading({ title: '加载中...', }) wx.downloadFile({ url: that.data.url, success: function (res) { that.setData({ tempFilePath:res.tempFilePath }) let filePath = res.tempFilePath console.log(filePath) that.downFile() }, fail: function (error) { console.log(error); wx.showToast({ title: '文件下载失败', icon: 'error' }) wx.hideLoading() } }) },
onReady() {
},
onShow() {
},
onHide() {
},
onUnload() {
},
onPullDownRefresh() {
},
onReachBottom() {
},
onShareAppMessage() {
}, downFile() { wx.showLoading({ title: '文件保存中', }) let that = this wx.saveFile({ tempFilePath: that.data.tempFilePath, success: (res) => { let filePath = res.savedFilePath wx.showToast({ title: '保存成功:' + filePath, icon: 'none' }) setTimeout(() => { wx.hideLoading({ success: (res) => { wx.navigateBack({ delta: 1, }) }, }) }, 1500);
}, fail: (err) => { debugger wx.showToast({ title: '文件保存失败', icon: 'error' }) console.log(err) } }) } })
|
效果图
参考
uniapp微信小程序使用webview嵌套h5的文件下载问题 - CSDN
微信小程序web-view与H5 通信方式探索 - 知乎
微信小程序中webView的H5与小程序通信 - 掘金
web-view - 微信小程序官方文档