ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
download 属性とは
<a> 要素の download 属性は、リンク先をブラウザで開かずにダウンロードして保存させるための属性です。PDF や画像のようにブラウザが普段ビューアで表示してしまうファイルを、確実に「保存」として扱わせたい場合に使います。
基本構文
1. ファイル名を指定しない(サーバ側の名前で保存)
<a href="/files/manual.pdf" download>マニュアルをダウンロード</a>
2. ファイル名を指定する
<a href="/files/20260611-abc123.pdf" download="マニュアル.pdf">
マニュアルをダウンロード
</a>
サーバ上のハッシュ付きファイル名を、ユーザーが見やすい名前で保存させる典型パターンです。
使えるケース・使えないケース
同一オリジンまたは blob: / data: URL のときだけ有効です。クロスオリジンの URL では、ブラウザは安全のため download を無視します(通常のリンクとして開く)。
| リンク先 | download 属性 |
|---|---|
| 同じドメインのファイル | ○ 有効(ファイル名指定も可) |
blob: URL | ○ 有効 |
data: URL | ○ 有効 |
| 別ドメインのファイル | × 無視(リンクとして開かれる) |
同じドメインに Content-Disposition: attachment | サーバ側が優先 |
ファイル名指定の挙動
- download のみ → サーバ側のファイル名(URL 末尾)で保存
- download="name.ext" → その名前で保存
- サーバ側で
Content-Disposition: attachment; filename="..."がある場合、サーバ側が優先される実装が多い - 拡張子は自動補完されない(
download="data"なら拡張子なし) - OS で使えない文字(
/や:など)は自動でアンダースコア等に置換される
典型的なユースケース
PDF を「表示」ではなく「保存」させる
ブラウザは PDF をビューアで開いてしまうことが多いですが、download を付けると保存ダイアログが出ます。
<a href="/docs/report.pdf" download>レポートをダウンロード</a>
画像を保存させる
右クリックして保存しなくても、ボタン感覚でダウンロードできます。
<a href="/img/photo.jpg" download="my-photo.jpg">
写真を保存
</a>
JS で生成したテキストを保存する
Blob を URL.createObjectURL で URL 化し、それを download 付きリンクとしてクリックします。CSV / JSON / ログ出力でよく使う定番パターンです。
function downloadText(filename, text) {
const blob = new Blob([text], { type: "text/plain;charset=utf-8" });
const url = URL.createObjectURL(blob);
const a = document.createElement("a");
a.href = url;
a.download = filename;
document.body.appendChild(a);
a.click();
a.remove();
URL.revokeObjectURL(url); // メモリ解放
}
// CSV をダウンロード
downloadText("data.csv", "name,age\nAlice,30\nBob,25");
data: URL で小さなファイルを保存する
<a href="data:text/plain;charset=utf-8,Hello%20World" download="hello.txt">
hello.txt をダウンロード
</a>
サーバ側からも強制ダウンロードする
クロスオリジンや確実性が求められる場面では、サーバ側のレスポンスヘッダでダウンロード扱いにします。HTML だけに頼るより堅実です。
Content-Disposition: attachment; filename="report.pdf"
Content-Type: application/pdf
PHP の例:
header('Content-Type: application/pdf');
header('Content-Disposition: attachment; filename="report.pdf"');
readfile('/var/files/report.pdf');
ブラウザ対応状況
- Chrome / Edge / Firefox / Safari ともに対応(モダンブラウザ)
- iOS Safari は仕様上の制約で挙動が独特 — ファイルが新しいタブで開いてしまうケースがある
- クロスオリジン URL は前述のとおりすべてのブラウザで無視される
セキュリティ上の注意
- ユーザー入力の値を download に直接埋めない — 拡張子偽装などの攻撃に繋がる可能性
- 外部 URL に対しては効かない仕様なので、過信しない
- ダウンロードファイル自体はサーバ側で適切な Content-Type / Disposition を返すのがベストプラクティス
JS から動的にダウンロードを発火する
すでに DOM 上にあるリンクに頼らず、ボタンクリックをトリガに JS でファイルを作って即ダウンロードさせるパターンも頻出です。コードでは「不可視のリンクを作って click() を呼び、すぐ取り除く」のがイディオムです。
async function downloadFromApi(apiUrl, filename) {
const res = await fetch(apiUrl);
const blob = await res.blob();
const url = URL.createObjectURL(blob);
const a = document.createElement("a");
a.href = url;
a.download = filename;
a.style.display = "none";
document.body.appendChild(a);
a.click();
a.remove();
URL.revokeObjectURL(url);
}
// 例: API レスポンスを PDF として保存
downloadFromApi("/api/report.pdf", "report.pdf");
ボタンとして見せる
意味的にダウンロードリンクは <a> ですが、見た目をボタン風にするのは CSS だけで完結します。
.download-btn {
display: inline-block;
padding: 10px 20px;
background: #2563eb;
color: #fff;
border-radius: 6px;
text-decoration: none;
font-weight: bold;
}
.download-btn:hover { background: #1d4ed8; }
関連
- a 要素 — ハイパーリンク
- href 属性 — リンク先 URL
- target 属性 — リンクを開くウィンドウ
- Blob / URL.createObjectURL — JS でのファイル生成
- Content-Disposition — サーバ側でのダウンロード指定
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
子ページはありません
- href属性
- target属性
- download 属性
- rel 属性
- hreflang属性
- type属性
人気ページ
- 1 Eclipseで「サーバーに追加または除去できるリソースがありません。」の原因と対処法
- 2 tomcat の起動 / 停止ログと catalina.log・catalina.out の違い
- 3 JavaScript base URL 取得方法|window.location.origin と SSR/Node.js 対応
- 4 YouTube Data API v3 エラー一覧|403/400/404 の主要原因と切り分け
- 5 Spring Frameworkのアノテーション一覧
- 6 Laravel エラー一覧|500/Blade/DB 接続/ルーティングの代表エラー
- 7 3Dグラフィックスとは|モデリング/レンダリング/主要ソフトウェア (Blender / Maya)
- 8 【Spring】@Valueアノテーションとは
- 9 CATALINA_HOME の確認方法 (Linux / Mac)
- 10 【Spring】@Autowiredアノテーションとは
最近更新/作成されたページ
- IPv6とは|128bitアドレス・コロン16進表記/::省略・リンクローカル・SLAAC・デュアルスタック 2026-06-22 12:34:44
- VPNとは|暗号トンネル・サイト間/リモートアクセス・IPsec/SSL-VPN/WireGuardを解説 2026-06-22 12:19:10
- MAC アドレスフィルタリングの仕組みと限界 | ネットワーク入門 2026-06-22 12:19:10
- gRPC とは HTTP/2 + Protocol Buffers の高速 RPC | ネットワーク入門 2026-06-22 12:17:25
- WebSocket とは 全二重リアルタイム通信 ws/wss | ネットワーク入門 2026-06-22 12:17:25
- WebRTC とは ブラウザ間 P2P の音声・映像・データ通信 | ネットワーク入門 2026-06-22 12:17:25
- HTTP/3 (QUIC) とは UDP ベースの低遅延 Web 通信 | ネットワーク入門 2026-06-22 12:17:25
- HTTP/2 とは 多重化・HPACK・バイナリフレーム | ネットワーク入門 2026-06-22 12:17:25
- Web通信プロトコル入門 HTTP/2・HTTP/3・WebSocket・gRPC・WebRTC | ネットワーク入門 2026-06-22 12:17:25
- 証明書と認証局(CA)とは|X.509・信頼チェーン・DV/OV/EV・失効(CRL/OCSP)を解説 2026-06-22 12:17:24
- ファイアウォールとは|パケットフィルタ・ステートフル・DMZ・次世代FW(L4/L7)を解説 2026-06-22 12:17:24
- iptables/nftablesとは|テーブル・チェーン・ルール例・永続化をLinux視点で解説 2026-06-22 12:17:24
- HAProxy とは frontend/backend と設定例 | ネットワーク入門 2026-06-22 12:17:24
- TLS/SSLの仕組み|ハンドシェイク・暗号スイート・前方秘匿性・証明書検証をわかりやすく解説 2026-06-22 12:17:24
- CDN とは エッジキャッシュ・TTL・Cloudflare/CloudFront | ネットワーク入門 2026-06-22 12:17:24
コメントを削除してもよろしいでしょうか?