欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

vue項目使用jszip和file-saver批量打包壓縮圖片或附件方式

 更新時間:2024年03月08日 09:47:33   作者:小破孩呦  
這篇文章主要介紹了vue項目使用jszip和file-saver批量打包壓縮圖片或附件方式,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教

使用jszip和file-saver批量打包壓縮圖片或附件

背景:

圖片上傳功能用戶會批量上傳好多個,并且圖片可能還會很大,于是就采用了前端先壓縮,然后將壓縮包直接傳給后端。

1、安裝插件:

npm install jszip
npm install file-saver

2、在頁面中引入插件:

import JSZip from 'jszip';
import FileSaver from 'file-saver'; 
// 定義全局的 zip
const zip = new JSZip();

注釋:在引入組件的位置定義一個全局的 zip 用于文件的壓縮

3、element UI 上傳組件:

<el-upload
    class="upload-demo"
    accept=".jpg,.JPG,.png,.PNG"
    action="#"
    :multiple="true"
    :auto-upload="false"
    :on-change="handleChange1"
    :show-file-list="false"
    :file-list="fileList1">
    <el-button size="small" type="primary">選擇文件</el-button>
</el-upload>
<el-button class="handle-upload" size="small" type="primary" @click="uploadData()" :loading="loadingFile1">開始上傳</el-button>

4、初始化 data 數據:

export default {
    data() {
        return {
            fileList1: [], // 待上傳圖片數據
        }
    }
}

5、添加圖片選擇的 onchange 方法:

export default {
    methods: {
        // 上傳圖片
        handleChange1(file, fileList) {
            const that = this;
            const _file = file.raw;
            let blob = new Blob([_file], { type: _file.type});
            zip.file(_file.name, blob);
            this.fileList1 = fileList;
        },
        // 開始上傳
        uploadData(){
            // 生成 ZIP 文件
            zip.generateAsync({ type: 'blob' })
            .then(function (zipBlob) {
                // 在這里可以進行上傳操作,將 zipBlob 發(fā)送到服務器
                // 也可以通過 FileSaver.js 將 ZIP 文件保存到本地
                FileSaver.saveAs(zipBlob, '壓縮包名稱.zip');
             })
             .catch(function (error) {
                console.error('壓縮視頻失敗:', error);
             });
        }
    }
}

注釋:zip. 屬性是在第二步中進行定義的,具體請參考第二步

至此前端附件壓縮完成?。?!

附加:從服務器獲取附件,進行壓縮下載

1、安裝插件:

npm install jszip

2、在頁面中引入插件:

import JSZip from 'jszip';

3、第3 、4步同上

5、添加圖片選擇的 onchange 方法:

export default {
    methods: {
        // 圖片壓縮前轉換
        imgToBuffer(url) {
           return new Promise((resolve, reject) => {
             const xml = new XMLHttpRequest();
             xml.open('GET', url, true);
             xml.responseType = 'blob';
             xml.onload = function ({ currentTarget }) { //從事件對象結構出currentTarget
               const { status, response } = currentTarget;
               status === 200 ? resolve(response) : reject(status); // response就是轉化后的
             };
             xml.send();
           });
        },
        // 開始壓縮
        uploadData(){
            const zip = new JSZip();
            const imgCache = {};
            const imgArr = [];
            let list = [
                    {name: '測試圖片1', url: 'https://t7.baidu.com/it/u=1595072465,3644073269&fm=193&f=GIF'},
                    {name: '測試圖片2', url: 'https://t7.baidu.com/it/u=727460147,2222092211&fm=193&f=GIF'},
                    {name: '測試圖片3', url: 'https://t7.baidu.com/it/u=3911840071,2534614245&fm=193&f=GIF'},
                    {name: '測試圖片4', url: 'https://t7.baidu.com/it/u=938052523,709452322&fm=193&f=GIF'},
             ];
             list.forEach((item) => { // urlList格式:[{url:圖片鏈接,name:圖片名稱}...]
                // 逐個添加文件
                const promise = this.imgToBuffer(item.url).then((res) => { 
                    zip.file(`${item.name}.${res.type.split('/').pop()}`, res, { binary: true }); 
                    imgCache[item.name] = res; // 下載文件, 并存成ArrayBuffer對象(blob)
                });
                imgArr.push(promise);
            });
            Promise.all(imgArr).then(() => {
                zip.generateAsync({ type: 'blob' }).then((content) => {
                    saveAs(content, '壓縮包名稱'); // 打包壓縮
                    this.$message.success('壓縮完成');
                }).catch((err) => {
                    this.$message.error(err.message);
                });
            });
        }
    }
}

至此完成壓縮下載!?。?/p>

總結

以上測試有效,感謝支持?。?!

這些僅為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。

相關文章

  • Django+Vue實現WebSocket連接的示例代碼

    Django+Vue實現WebSocket連接的示例代碼

    這篇文章主要介紹了Django+Vue實現WebSocket連接的示例代碼,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2019-05-05
  • vue選項卡組件的實現方法

    vue選項卡組件的實現方法

    這篇文章主要為大家詳細介紹了vue選項卡組件的實現方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-03-03
  • 淺析vue-router實現原理及兩種模式

    淺析vue-router實現原理及兩種模式

    這篇文章主要介紹了vue-router實現原理及兩種模式分析,給大家介紹了vue-router hash模式與history模式不同模式下處理邏輯,需要的朋友可以參考下
    2020-02-02
  • 解決vue初始化項目時,一直卡在Project description上的問題

    解決vue初始化項目時,一直卡在Project description上的問題

    今天小編就為大家分享一篇解決vue初始化項目時,一直卡在Project description上的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-10-10
  • vue.js 實現輸入框動態(tài)添加功能

    vue.js 實現輸入框動態(tài)添加功能

    這篇文章主要介紹了vue.js 實現輸入框動態(tài)添加功能,非常不錯,具有一定的參考借鑒價值,需要的朋友可以參考下
    2018-06-06
  • Vue中虛擬列表的原理與實現詳解

    Vue中虛擬列表的原理與實現詳解

    虛擬列表是一種技術,它只渲染用戶當前可見的列表項,而不是渲染整個列表,這篇文章主要來和大家聊聊虛擬列表的原理與實現,希望對大家有所幫助
    2023-05-05
  • vue 按鈕 權限控制介紹

    vue 按鈕 權限控制介紹

    這篇文章主要介紹了vue 按鈕 權限控制,在日常項目中,會碰到需要根據后臺接口返回的數據,來判斷當前用戶的操作權限,必須當有刪除權限時,就顯示刪除按鈕,下面我們就來了解一下具體的解決方法,需要的朋友也可以參考一下
    2021-12-12
  • Element實現動態(tài)增加多個輸入框并校驗

    Element實現動態(tài)增加多個輸入框并校驗

    本文主要介紹了Element實現動態(tài)增加多個輸入框并校驗,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2023-07-07
  • 在vue中nextTick用法及nextTick 的原理是什么

    在vue中nextTick用法及nextTick 的原理是什么

    這篇文章主要介紹了在vue中nextTick用法及nextTick 的原理是什么,Vue.js 是一個流行的前端框架,它提供了一種響應式的數據綁定機制,使得頁面的數據與頁面的 UI 組件之間能夠自動同步,需要的朋友可以參考下
    2023-04-04
  • Vue異步加載about組件

    Vue異步加載about組件

    這篇文章主要為大家詳細介紹了Vue異步加載about組件的相關方法,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-10-10

最新評論