{
    "componentChunkName": "component---src-templates-blog-post-jsx",
    "path": "/post/how-to-download-with-a-tag-without-file-server/",
    "result": {"data":{"site":{"siteMetadata":{"title":"WEB EGG","author":"Leko - CTO at Yuimedi"}},"markdownRemark":{"id":"5dc301e8-7edc-5f5d-a18b-6223ba578c3c","excerpt":"この記事はHTML5 Advent calendarの16日目の記事です。 HTML5からaタグにdownloadという属性が指定可能になったようです。 この属性が指定されたaタグは、href属性の値をブラウザで開くのではなく、リンク先をファイルとしてダウンロードします。 今までcanvas…","html":"<p>この記事は<a href=\"http://qiita.com/advent-calendar/2015/html5\" target=\"_blank\" rel=\"nofollow noopener noreferrer\">HTML5 Advent calendar</a>の16日目の記事です。</p>\n<p>HTML5からaタグにdownloadという属性が指定可能になったようです。<br>\nこの属性が指定されたaタグは、href属性の値をブラウザで開くのではなく、リンク先をファイルとしてダウンロードします。</p>\n<p>今までcanvasで画像を生成した画像など、jsで生成したファイルをユーザに保存させるには<code>window.open</code>にdata urlを渡して新窓で表示させ、ユーザに右クリ等で保存してもらう方法しか知らなかったのですが、<br>\naタグの<code>download</code>属性がまさにやりたいことドンピシャだったので備忘録を残します。</p>\n<!--more-->\n<h2 id=\"デモ\" style=\"position:relative;\"><a href=\"#%E3%83%87%E3%83%A2\" aria-label=\"デモ permalink\" class=\"autolink-header before\"><svg aria-hidden=\"true\" focusable=\"false\" height=\"16\" version=\"1.1\" viewBox=\"0 0 16 16\" width=\"16\"><path fill-rule=\"evenodd\" d=\"M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z\"></path></svg></a>デモ</h2>\n<p><a href=\"https://developer.mozilla.org/en-US/docs/Web/HTML/Element/a#Using_the_download_attribute_to_save_a_canvas_as_a_PNG\" target=\"_blank\" rel=\"nofollow noopener noreferrer\">MDN</a>にまさにドンピシャな<a href=\"http://jsfiddle.net/codepo8/V6ufG/2/\" target=\"_blank\" rel=\"nofollow noopener noreferrer\">デモ</a>があったので、自作デモは割愛します。<br>\ncanvasで生成した画像を新窓ではなくファイルダウンロードさせるデモです。</p>\n<p><strong>このとき、サーバに対して一切リクエストを飛ばしていないことがポイントです</strong></p>\n<h2 id=\"よいこと\" style=\"position:relative;\"><a href=\"#%E3%82%88%E3%81%84%E3%81%93%E3%81%A8\" aria-label=\"よいこと permalink\" class=\"autolink-header before\"><svg aria-hidden=\"true\" focusable=\"false\" height=\"16\" version=\"1.1\" viewBox=\"0 0 16 16\" width=\"16\"><path fill-rule=\"evenodd\" d=\"M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z\"></path></svg></a>よいこと</h2>\n<ul>\n<li>わざわざバイナリをechoするだけのサーバを立てなくて良い</li>\n<li>上記の構築や管理・メンテの手間がなくなる</li>\n<li>jsだけで完結するのでコードのまとまりが良くなる</li>\n</ul>\n<p>あたりが個人的に良いと思うところです。</p>\n<h2 id=\"jsからaタグを生成しファイル名を指定してダウンロード\" style=\"position:relative;\"><a href=\"#js%E3%81%8B%E3%82%89a%E3%82%BF%E3%82%B0%E3%82%92%E7%94%9F%E6%88%90%E3%81%97%E3%83%95%E3%82%A1%E3%82%A4%E3%83%AB%E5%90%8D%E3%82%92%E6%8C%87%E5%AE%9A%E3%81%97%E3%81%A6%E3%83%80%E3%82%A6%E3%83%B3%E3%83%AD%E3%83%BC%E3%83%89\" aria-label=\"jsからaタグを生成しファイル名を指定してダウンロード permalink\" class=\"autolink-header before\"><svg aria-hidden=\"true\" focusable=\"false\" height=\"16\" version=\"1.1\" viewBox=\"0 0 16 16\" width=\"16\"><path fill-rule=\"evenodd\" d=\"M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z\"></path></svg></a>jsからaタグを生成し、ファイル名を指定してダウンロード</h2>\n<div class=\"gatsby-highlight\" data-language=\"javascript\"><pre class=\"language-javascript\"><code class=\"language-javascript\"><span class=\"token keyword\">function</span> <span class=\"token function\">download</span><span class=\"token punctuation\">(</span><span class=\"token parameter\">uri<span class=\"token punctuation\">,</span> filename</span><span class=\"token punctuation\">)</span> <span class=\"token punctuation\">{</span>\n  filename <span class=\"token operator\">=</span> filename <span class=\"token operator\">||</span> <span class=\"token string\">'file'</span><span class=\"token punctuation\">;</span>\n\n  <span class=\"token keyword\">var</span> link <span class=\"token operator\">=</span> document<span class=\"token punctuation\">.</span><span class=\"token function\">createElement</span><span class=\"token punctuation\">(</span><span class=\"token string\">'a'</span><span class=\"token punctuation\">)</span><span class=\"token punctuation\">;</span>\n  link<span class=\"token punctuation\">.</span>download <span class=\"token operator\">=</span> filename<span class=\"token punctuation\">;</span>\n  link<span class=\"token punctuation\">.</span>href <span class=\"token operator\">=</span> uri<span class=\"token punctuation\">;</span>\n  link<span class=\"token punctuation\">.</span><span class=\"token function\">click</span><span class=\"token punctuation\">(</span><span class=\"token punctuation\">)</span><span class=\"token punctuation\">;</span>\n<span class=\"token punctuation\">}</span>\n\n<span class=\"token function\">download</span><span class=\"token punctuation\">(</span><span class=\"token string\">'data://text/html,Hello world!!'</span><span class=\"token punctuation\">,</span> <span class=\"token string\">'dummy.html'</span><span class=\"token punctuation\">)</span><span class=\"token punctuation\">;</span></code></pre></div>\n<p>のように、location.hrefなどと大差ないくらいの手軽さでサッと書けるのが魅力だと思います。<br>\nこれでフロントエンドだけで完結するアプリケーションがより作りやすくなりました。</p>\n<h2 id=\"ブラウザ互換\" style=\"position:relative;\"><a href=\"#%E3%83%96%E3%83%A9%E3%82%A6%E3%82%B6%E4%BA%92%E6%8F%9B\" aria-label=\"ブラウザ互換 permalink\" class=\"autolink-header before\"><svg aria-hidden=\"true\" focusable=\"false\" height=\"16\" version=\"1.1\" viewBox=\"0 0 16 16\" width=\"16\"><path fill-rule=\"evenodd\" d=\"M4 9h1v1H4c-1.5 0-3-1.69-3-3.5S2.55 3 4 3h4c1.45 0 3 1.69 3 3.5 0 1.41-.91 2.72-2 3.25V8.59c.58-.45 1-1.27 1-2.09C10 5.22 8.98 4 8 4H4c-.98 0-2 1.22-2 2.5S3 9 4 9zm9-3h-1v1h1c1 0 2 1.22 2 2.5S13.98 12 13 12H9c-.98 0-2-1.22-2-2.5 0-.83.42-1.64 1-2.09V6.25c-1.09.53-2 1.84-2 3.25C6 11.31 7.55 13 9 13h4c1.45 0 3-1.69 3-3.5S14.5 6 13 6z\"></path></svg></a>ブラウザ互換</h2>\n<p><a href=\"http://caniuse.com/#search=download\" target=\"_blank\" rel=\"nofollow noopener noreferrer\">Can I use</a>によると、IEとSafari(Mac、iOS）は最新版でも動きません。<br>\nChrome、Firefox限定のアプリケーションなどでは使用できそうです。<br>\nあと機種に依りそうですが、Androidのブラウザでは動作するようです。</p>","timeToRead":2,"frontmatter":{"title":"aタグのdownload属性でサーバを介さずにファイルダウンロードする","tags":["HTML5 Canvas"],"date":"December 15, 2015","featuredImage":null}}},"pageContext":{"slug":"/how-to-download-with-a-tag-without-file-server/","previous":{"fields":{"slug":"/how-to-disable-limitation-of-cors-in-html5-canvas/"},"frontmatter":{"title":"canvasのCORS制限を突破する","tags":["HTML5 Canvas","JavaScript","security"]}},"next":{"fields":{"slug":"/how-to-create-native-apps-with-fluid-from-web-apps/"},"frontmatter":{"title":"Fluidで任意のWebページをアプリ化する","tags":["Google Analytics","Mac"]}}}},
    "staticQueryHashes": ["2585454260","2954598359"]}