详解基于mpvue微信小程序下载远程图片到本地解决思路
更新时间:2019年05月16日 14:22:44 作者:hurely
这篇文章主要介绍了详解基于mpvue微信小程序下载远程图片到本地解决思路,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
说明
最近有些空余时间开始着手优化我那个吉他自学小助手的微信小程序,其中有一个功能是下载吉他谱到本地,开始以为只是很简单的拿到图片url然后down下来就好了,其实不然...最终通过google解决了这个问题,现在记录一下,以便后续翻阅。
少废话先看东西
演示.gif
流程梳理
获取图片远程地址数组-->遍历拿到图片缓存(临时地址)(wx.getImageInfo)-->保存缓存图片到本地(wx.saveImageToPhotosAlbum)
完整代码
子组件代码逻辑
//子组件download-file.vue <template> <div></div> </template> <script> export default { props: { urls: { default: ""//通过父组件传递远程图片路径数组 } }, watch: { urls() { if (this.urls.length > 0) { this.downLoadImage(this.urls);//监听变化 } } }, methods: { //拿到图片的临时路径 getImageInfo(url) { var cache = {}; return new Promise((resolve, reject) => { /* 获得要在画布上绘制的图片 */ if (cache[url]) { resolve(cache[url]); } else { const objExp = new RegExp( /^http(s)?:\/\/([\w-]+\.)+[\w-]+(\/[\w- .\/?%&=]*)?/ ); if (objExp.test(url)) { wx.getImageInfo({ src: url, complete: res => { if (res.errMsg === "getImageInfo:ok") { cache[url] = res.path; resolve(res.path); } else { reject(new Error("getImageInfo fail")); } } }); } else { this.cache[url] = url; resolve(url); } } }); }, downLoadImage(urls) { const vm = this; let temp = []; if (urls.length > 0) { urls.map((item, index) => { vm.getImageInfo(item).then(res => { temp.push(res); vm.saveImageToLocal(res); }); }); } }, saveImageToLocal(path) { //保存临时图片到本地 wx.saveImageToPhotosAlbum({ filePath: path, success(res) { console.log("success"); }, fail: function(res) { console.log(res); } }); } } }; </script> <style> </style>
在父组件中引用
//news/detail.vue //省略代码... <button @click="download">下载</button> //省略代码... <download-file :urls="downLoadUrls" ref="myDownload"></download-file> //省略代码... async download() { let vm = this; const temp = []; let data = await vm.$net.get(vm.$apis.articleDetails, { id: vm.item.id }); if (data.article.body.length > 0) { data.article.body.map((item, index) => { if (item.type == "img") { temp.push(item.data); } }); } vm.downLoadUrls = temp; },
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
相关文章
vue3 + element-plus 的 upload + axios + django 实现文件上
这篇文章主要介绍了vue3 + element-plus 的 upload + axios + django 文件上传并保存,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧2024-01-01Vue的Eslint配置文件eslintrc.js说明与规则介绍
最近在跟着视频敲项目时,代码提示出现很多奇奇怪怪的错误提示,百度了一下是eslintrc.js文件没有配置相关命令,ESlint的语法检测真的令人抓狂,现在总结一下这些命令的解释2020-02-02
最新评论