微信公众号H5开发,在微信浏览器打开H5,无法一键下载图片

微信公众号H5开发,在微信浏览器打开H5,无法一键下载图片

背景

微信公众号H5开发,在普通浏览器,可以直接通过以下代码下载图片:

let a = document.createElement('a')
a.style.display = 'none'
a.href = ‘https://www.图片地址.com’
a.setAttribute('download', '我的图片.jpg')
document.body.appendChild(a)
a.click() //执行下载
window.URL.revokeObjectURL(a.href)
document.body.removeChild(a)     

但是在微信浏览器,上面那段代码是无效的,这是微信浏览器的限制。

微信的JS-SDK提供 wx.downloadImage() 的方法,是用来下载图片的。但其实我觉得应该是用来耍猴的。该方法不接受一个 url 参数,而是接受一个 serverId。serverId 从哪来,从另一个方法wx.uploadImage() 里面获得。wx.uploadImage() 方法用于上传本地的图片,但上传成功后,回调函数就能拿到一个 serverId。上传到哪?微信自己的服务器。如果你想保存到自己公司的服务器,你还得让公司服务器调用多媒体接口,从微信服务器拿回图片。而且,微信服务器只给你保存 3 天时间。是的,你能下载的图片的图片来自用户的上传,且只有三天有效期。另外,下载的图片貌似也不会保存到相册里,而是保存在用户找不到的地方。结论就是完全没法用。

但是,在微信浏览器中,长按图片是可以保存的。

实际上,图片、视频以及文档文件(pdf、word 等)都无法通过js原生方法进行下载,而是打开一个新的页面让你预览。但对于其他微信不能预览的文件(如果 zip 压缩包)来说,则会将其下载下来。对于展示出来的图片,用户可以长按图片保存下来。

解决方案

  1. 首先要判断浏览器是否为微信浏览器,如果不是微信浏览器,下载保持原来逻辑。
  2. 如果是图片,点击下载按钮时弹出弹窗,提示用户长按图片下载。
  3. 如果是视频或文档文件,提示用户使用默认浏览器去下载文件。考虑到用户用新的浏览器又要登陆很麻烦,引导用户点击右上角将链接用默认浏览器打开并不是好方案。我们可以在点击下载按钮时,复制文件链接,然后让用户自行打开默认浏览器粘贴链接下载。这种占用用户剪贴板的行为其实不太好。或者直接将下载按钮屏蔽掉算了,又或是弹出只能在 PC 端下载的提示。
  4. 如果是其他类型文件,可以直接下载,无限制。

文章参考

https://zhuanlan.zhihu.com/p/485755669?utm_id=0

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
微信公众号 H5 开发中,如果需要进行横屏签名,需要按照以下步骤进行: 1. 在页面头部添加 meta 标签,设置 viewport 的宽度和高度,以及 initial-scale、maximum-scale 和 minimum-scale 等属性,例如: ```html <meta name="viewport" content="width=device-width, height=device-height, initial-scale=1.0, maximum-scale=1.0, minimum-scale=1.0, user-scalable=no, target-densitydpi=device-dpi"> ``` 2. 在 CSS 样式表中设置 body 元素的样式,例如: ```css body { -webkit-transform: rotate(90deg); -moz-transform: rotate(90deg); -ms-transform: rotate(90deg); -o-transform: rotate(90deg); transform: rotate(90deg); transform-origin: left top 0; width: 100vh; height: 100vw; overflow-x: hidden; position: absolute; top: 100%; left: 0; } ``` 其中,-webkit-transform、-moz-transform、-ms-transform 和 -o-transform 是为了兼容不同的浏览器内核,transform-origin 是设置旋转的中心点,width 和 height 分别设置页面的宽度和高度,overflow-x:hidden 是为了隐藏横向滚动条,position:absolute、top:100% 和 left:0 是为了把页面移动到底部位置。 3. 在 JavaScript 中监听窗口大小变化事件,重新计算页面样式,例如: ```js window.addEventListener('resize', function() { var width = window.innerWidth; var height = window.innerHeight; if (width < height) { document.body.classList.add('portrait'); document.body.classList.remove('landscape'); } else { document.body.classList.add('landscape'); document.body.classList.remove('portrait'); } }); ``` 其中,如果窗口宽度小于高度,则添加 portrait 类,否则添加 landscape 类,然后在 CSS 样式表中设置不同的样式,以适应不同的屏幕方向。 以上就是微信公众号 H5 开发中如何进行横屏签名的步骤,希望能对你有帮助。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值