はじめに 先日、仕事でrails(API) + Nuxtでファイルダウンロード機能を作ったのでメモしておきます。 業務で実装したCSVダウンロードの実装手順をざっくり説明すると、以下のような形となります。 # 実装手順 - 1.nuxtからAPI(rails)を叩く - 2.text/csv形式のデータをrailsから返す - 3.nuxtから返ってきたapiレスポンスデータをダウンロードさせる 今回は3のNuxtからファイルダウンロード処理だけを説明します。 いきなり、結論 フロントエンドの方に教えてもらったのですが、 この記事 が参考になります。(というかそのまんまコピペでイケますね。。) // バイナリ形式で作成 const blob = new Blob([response.data], { type: "text/csv" }); const url = (window.URL