【Nodejs】JSzipでファイルダウンロード機能を実装する

JavascriptでのZIP生成&ファイルダウンロード

Nodejs系でユーザーにダウンロードさせたいファイルをまとめてZIPにボタンをクリックすると<a>タグを発火させてファイルダウンロードが始まる的な機能を実装する方法はアカイバーを使ったり色々あるが、個人的にはJszipが一番使いやすかったので使い方をメモしておきます。

# JSZIPのインストール
npm install jszip

# 必要なライブラリを読み込む
import { Buffer } from 'buffer';
import * as JSZip from 'jszip';


file_export(): void{
    # zipに書き込むデータ(実際はAPIなどから取得する/画像の場合はbase64で返ってくることを想定)
    let data = '44GT44KT44Gr44Gh44Gv44Gb44GL44GE'
    let csv = '1,2,3,4,5,6,' 

    # インスタンス生成
    let zip = new JSZip();

    # ZIP生成
    zip.file('export.csv', Buffer.from(csv, 'base64').toString());
    for (var i = 0; i < 100; i++) {
        zip.file(`export_${i}.jpg`, Buffer.from(data, 'base64').toString());
        }
    let content = await zip.generateAsync({ type: 'blob' })

    # aタグを生成→クリックで発火処理を実装
    let link = document.createElement('a');
    link.href = window.URL.createObjectURL(content);
    link.download = 'test.zip';
    link.click();
    }

モダンなjsでは演算子awaitを付けておくと、非同期処理の中でも同期的に処理するようになるみたいです。非同期処理というと.thenでごちゃごちゃやるイメージだったんですけどいつの間にか時代は変わっていたみたいです。

ブログ運営者

・関連記事







プログラミングの独学はとても難しい


プログラミングは小学校の義務教育にも導入され始めており、これから社会人として生きていく上でプログラミングはもはや出来て当たり前、出来なれば論外というエクセルレベルの必須スキルになりつつあります。そしてそういう話を聞いて参考書なりを購入して独学でプログラミング勉強しようと思っている人も少なくないでしょう。しかしプログラミングを独学で勉強し始めようと思うものの



・「分からない箇所で詰まって挫折してしまった」

・「勉強する時間が足りない」

・「ネットの記事だと情報が断片的でよくわからない」

・「コードのエラーの原因が分からない」



という壁にぶち当たって、プログラミングの勉強を止めてしまう方が少なくありません。独学でプログラミングを勉強してる時間のほとんどはつまづいている時間です。実際僕も最初のころ独学でプログラミングを勉強していた頃はエラーの原因が分からず丸1日を不意にしてしまった・・・そんな苦い経験がありました。それで僕は一度はプログラミングの学習を諦めてしまいましたが、就活で現実を知る中で



「プログラミングを勉強して、いずれフリーランスとして自由な生き方がしたい」

「エンジニアとして若いうちから高収入を得たい」



という強い気持ちから一念発起して「侍エンジニアのwebサービスコース」に申し込み、プロのエンジニアの方に対面でマンツーマンでPythonによるWebサービス作り方とWeb技術の基本を教えてもらい、ようやくプログラミングが理解でき、今ではエンジニアとしてそこそこの暮らしができるようになりました。





侍エンジニアでは、とりあえずプログラミングやインターネットの基本を知っておきたい人から、HTML・cssなどでWebサイトやWebアプリを作ってみたい人やPythonを勉強してデータサイエンティストやAIエンジニアになりたい人まで幅広いニーズに応えた様々なコースが用意されています。



IT業界と言ってもエンジニアの仕事はプログラミング言語次第でサーバーから機械学習・ディープラーニングまで多種多様ですし、侍エンジニアの無料レッスン(カウンセリング)を受けてみて、自分のやりたいITの仕事は何なのか?を見つけるのがエンジニアへの第一歩になります。ちなみに今侍エンジニアの無料レッスンを受けると1000円分のAmazonギフト券がもらえるので、試しに受けてみるだけもお得です。


自分は半端に独学やオンラインスクールで勉強して金と時間を無駄にするくらいなら、リアルのプログラミングスクールに通ってしっかりプログラミングを勉強した方がいいと思います。ちなみに今、侍エンジニアに申し込むと、25歳以下の学生の方であれば、受講料が20%OFFになるので超お得です。


そして、プログラミングは大勢で授業を受けたり漫然とオンライン学習をするよりも自分が分からない箇所をピンポイントでプロの講師に直接質問して、ちゃんと納得するというスタイルの方がお金は確かに少し掛かりますが、独学で学ぶよりも絶対にモノになります。


シェアする

  • このエントリーをはてなブックマークに追加

フォローする