小程序保存多张图片优化版

18次阅读

共计 2409 个字符,预计需要花费 7 分钟才能阅读完成。

前言

之前写个一个版本的 [多图下载],重构进行了代码升级让代码更加简介
分为两步:
第一获取保存到相册权限
第二下载图片
主要涉及两个文件,index.js 和 download.js
另外现在如果有图片下载失败也弹出下载完成后续需要优化

核心代码

/**
 *  获取相册权限
 */
export function wxSaveAuth() {return new Promise((resolve, reject) => {
        wx.getSetting({success(res) {if (!res.authSetting['scope.writePhotosAlbum']) {
                    // 如果没有写入权限,则获取写入相册权限
                    wx.authorize({
                        scope: 'scope.writePhotosAlbum',
                        success() {resolve()
                        },
                        fail(err) {reject(err)
                            // 用户拒绝授权
                            wx.showModal({
                                content: '检测到您没打开捷买士的相册权限,是否去设置打开?',
                                confirmText: '确认',
                                cancelText: '取消',
                                success(res) {if (res.confirm) {
                                        wx.openSetting({success: res => {}
                                        })
                                    }
                                }
                            })
                        }
                    })
                } else {resolve()
                }
            },
            fail(e) {reject(e)
            }
        })
    })
}

/**
 * 多文件下载并且保存 
 * @param {Array} urls 网络图片数组
 */
export function downloadImgs(urls) {
    wx.showLoading({
        title: '图片下载中',
        mask: true
    })
    const imageList = []
    // 循环数组
    for (let i = 0; i < urls.length; i++) {imageList.push(getTempPath(urls[i]))
    }
    const loadTask = []
    let index = 0
    while (index < imageList.length) {
        loadTask.push(new Promise((resolve, reject) => {
                // 将数据分割成多个 promise 数组
                Promise.all(imageList.slice(index, (index += 8)))
                    .then(res => {resolve(res)
                    })
                    .catch(err => {reject(err)
                    })
            })
        )
    }
    // Promise.all 所有图片下载完成后弹出
    Promise.all(loadTask)
        .then(res => {
            wx.showToast({
                title: '下载完成',
                duration: 3000
            })
        })
        .catch(err => {
            wx.showToast({
                title: ` 下载完成 `,
                icon: 'none',
                duration: 3000
            })
        })
}
/**
 *
 * @param {String} url 单张网络图片
 */
// 下载内容, 临时文件路径
function getTempPath(url) {return new Promise((resolve, reject) => {
        wx.downloadFile({
            url: url,
            success: function(res) {
                var temp = res.tempFilePath
                wx.saveImageToPhotosAlbum({
                    filePath: temp,
                    success: function(res) {return resolve(res)
                    },
                    fail: function(err) {reject(url + JSON.stringify(err))
                    }
                })
            },
            fail: function(err) {reject(url + JSON.stringify(err))
            }
        })
    })
}
// pages/save-imgs/index.js
import {wxSaveAuth, downloadImgs} from '../../utils/download'
Page({
    /**
     * 页面的初始数据
     */
    data: {
        urls: [
             'https://avatars0.githubusercontent.com/u/35954879?s=120&v=4',
             'https://avatars0.githubusercontent.com/u/35954879?s=120&v=4',
             'https://avatars0.githubusercontent.com/u/35954879?s=120&v=4',
             'https://avatars0.githubusercontent.com/u/35954879?s=120&v=4',
             'https://avatars0.githubusercontent.com/u/35954879?s=120&v=4',
             'https://avatars0.githubusercontent.com/u/35954879?s=120&v=4',
             'https://avatars0.githubusercontent.com/u/35954879?s=120&v=4',
             'https://avatars0.githubusercontent.com/u/35954879?s=120&v=4'
    
        ]
    },

    /**
     * 生命周期函数 -- 监听页面加载
     */
    onLoad: function(options) {},

    download() {
        // 获取保存到相册权限
        wxSaveAuth().then(res => {
            // 保存多张图片到相册
            downloadImgs(this.data.urls)
        })
    },
 
})

项目案例

github 地址

git clone https://github.com/sunnie1992/sol-weapp.git

扫描添加下方的微信并备注 Sol 加交流群,交流学习,及时获取代码最新动态。

如果对你有帮助送我一颗小星星(づ~3~)づ╭❤~

正文完
 0