🖥

Nuxt 3 + npm exceljs でブラウザからエクセルファイルをダウンロードさせる #3540

2024/03/08に公開

ExcelJS

https://github.com/exceljs/exceljs

install

npm install exceljs

Vueファイルの例

<script setup>
import * as Excel from 'exceljs'

async function exportFile() {
  const workbook = new Excel.Workbook()

  // Sheet
  const worksheet = workbook.addWorksheet('My Sheet')

  // Header
  worksheet.columns = [
    { header: 'Id', key: 'id' },
    { header: 'Name', key: 'name' },
  ]

  // Rows
  worksheet.addRow([1, 'Alice'])
  worksheet.addRow([2, 'Bob'])

  // workbook to Blob
  const uint8Array = await workbook.xlsx.writeBuffer()
  const blob = new Blob([uint8Array], { type: 'application/octet-binary' })

  // Download
  const url = URL.createObjectURL(blob)
  const a = document.createElement('a')
  document.body.appendChild(a)
  a.download = `example.xlsx`
  a.href = url
  a.click()
  a.remove()
  URL.revokeObjectURL(url)
}
</script>

<template>
  <button @click="exportFile">Export XLSX</button>
</template>

概要

  • Exceljs でワークブックを組み立てる
  • Nuxtでダウンロードさせるには、Exceljsで作成したワークブックをBlobに変換した上で、ブラウザに対してはダウンロード処理を「偽装」する必要がありそうだ

ダウンロード例

参考

https://zenn.dev/knaka0209/books/309e88eb52352b/viewer/9b053f

チャットメンバー募集

何か質問、悩み事、相談などあればLINEオープンチャットもご利用ください。

https://line.me/ti/g2/eEPltQ6Tzh3pYAZV8JXKZqc7PJ6L0rpm573dcQ

プロフィール・経歴

https://github.com/YumaInaura/YumaInaura

公開日時

2024-02-29

Discussion