aboutsummaryrefslogtreecommitdiff
path: root/files/ja/web/api/file
diff options
context:
space:
mode:
authorMasahiro FUJIMOTO <mfujimot@gmail.com>2021-12-27 23:21:42 +0900
committerMasahiro FUJIMOTO <mfujimot@gmail.com>2022-01-06 20:42:33 +0900
commit95e1c12bd5362a61076119ef9289a8b68167e34b (patch)
tree6f498bbedaeab84e5c747a31d4d71884e20346c0 /files/ja/web/api/file
parent4e6ac017cdd1096518ad80347b6171cfd0cbd5de (diff)
downloadtranslated-content-95e1c12bd5362a61076119ef9289a8b68167e34b.tar.gz
translated-content-95e1c12bd5362a61076119ef9289a8b68167e34b.tar.bz2
translated-content-95e1c12bd5362a61076119ef9289a8b68167e34b.zip
2021/09/15 時点の英語版に同期
Diffstat (limited to 'files/ja/web/api/file')
-rw-r--r--files/ja/web/api/file/using_files_from_web_applications/index.md492
1 files changed, 259 insertions, 233 deletions
diff --git a/files/ja/web/api/file/using_files_from_web_applications/index.md b/files/ja/web/api/file/using_files_from_web_applications/index.md
index 07228aabd8..7409fc451e 100644
--- a/files/ja/web/api/file/using_files_from_web_applications/index.md
+++ b/files/ja/web/api/file/using_files_from_web_applications/index.md
@@ -1,105 +1,113 @@
---
-title: Web アプリケーションからのファイルの使用
+title: ウェブアプリケーションからのファイルの使用
slug: Web/API/File/Using_files_from_web_applications
tags:
- - Files
+ - ファイル
- HTML5
- - Intermediate
- - NeedsUpdate
- - ajax upload
- - upload
+ - 中級者
+ - 要更新
+ - ajax アップロード
+ - アップロード
translation_of: Web/API/File/Using_files_from_web_applications
---
-<div>{{APIRef("File API")}}</div>
+{{APIRef("File API")}}
-<p>HTML5 から DOM に追加された File API によって、ウェブコンテンツがユーザーにローカルファイルを選択するように指示し、それらのファイルを読み取れるようになりました。この選択は HTML の <code>{{HTMLElement("input/file", '&lt;input type="file"&gt;')}}</code> 要素か、ドラッグ&ドロップのどちらかを使用することで行うことができます。</p>
+File API は DOM に HTML5 で追加されたもので、ウェブコンテンツがユーザーにローカルファイルを選択するように指示し、それらのファイルを読み取ることができるようになりました。この選択は HTML の `{{HTMLElement("input/file", '&lt;input type="file"&gt;')}}` 要素を使用したり、ドラッグ&ドロップを行ったりすることで行うことができます。
-<p>File API を拡張機能や他の chrome コードから利用することもできます。この場合、もういくつか知っておきたい機能があります。詳細は <a href="/ja/docs/Extensions/Using_the_DOM_File_API_in_chrome_code">DOM File API を chrome code で使う</a> をご覧下さい。</p>
+File API を拡張機能や他のクロームコードから利用することもできます。この場合、もういくつか知っておきたい機能があります。詳細は [DOM File API をクロームコードで使う](/ja/docs/Extensions/Using_the_DOM_File_API_in_chrome_code)をご覧下さい。
-<h2 id="Accessing_selected_files" name="Accessing_selected_files">選択されたファイルへのアクセス</h2>
+## 選択されたファイルへのアクセス
-<p>この HTML を見てください。</p>
+この HTML を考えてください。
-<pre class="brush: html notranslate">&lt;input type="file" id="input"&gt;</pre>
+```html
+<input type="file" id="input" multiple>
+```
-<p>File API では、ユーザーが選択したファイルを表す {{DOMxRef("File")}} オブジェクトを含む {{DOMxRef("FileList")}} にアクセスすることができます。</p>
+File API により、ユーザーが選択したファイルを表す {{DOMxRef("File")}} オブジェクトを含む {{DOMxRef("FileList")}} にアクセスすることができます。
-<p><code>input</code> 要素の <code>multiple</code> 属性により、複数のファイルを選択することができます。</p>
+`multiple` 属性を `input` 要素に付けることで、ユーザーが複数のファイルを選択することができるようになります。
-<p>旧来の DOM セレクターを使って、最初に選択されたファイルにアクセスします。</p>
+旧来の DOM セレクターを使って、最初に選択されたファイルにアクセスします。
-<pre class="brush: js notranslate">const selectedFile = document.getElementById('input').files[0];</pre>
+```js
+const selectedFile = document.getElementById('input').files[0];
+```
-<h3 id="Accessing_selected_files_on_a_change_event" name="Accessing_selected_files_on_a_change_event">change イベントでの選択されたファイルへのアクセス</h3>
+### change イベントでの選択されたファイルへのアクセス
-<p><code>change</code> イベントを通して {{DOMxRef("FileList")}} にアクセスすることも可能です (ただし必須ではありません)。このように {{DOMxRef("EventTarget.addEventListener()")}} を使って <code>change</code> イベントのリスナーを追加する必要があります。</p>
+`change` イベントを通して {{DOMxRef("FileList")}} にアクセスすることもできます (ただし必須ではありません)。このように {{DOMxRef("EventTarget.addEventListener()")}} を使って `change` イベントのリスナーを追加する必要があります。
-<pre class="brush: js notranslate">const inputElement = document.getElementById("input");
+```js
+const inputElement = document.getElementById("input");
inputElement.addEventListener("change", handleFiles, false);
function handleFiles() {
const fileList = this.files; /* ファイルリストを処理するコードがここに入る */
-}</pre>
+}
+```
-<h2 id="Getting_information_about_selected_files" name="Getting_information_about_selected_files">選択されたファイルについての情報の取得</h2>
+## 選択されたファイルについての情報の取得
-<p>DOM が提供する {{DOMxRef("FileList")}} オブジェクトは、{{DOMxRef("File")}} オブジェクトとして指定された、ユーザーが選択したすべてのファイルをリストアップします。ファイルリストの <code>length</code> 属性の値をチェックすることで、ユーザーが選択したファイルの数を知ることができます。</p>
+DOM が提供する {{DOMxRef("FileList")}} オブジェクトは、{{DOMxRef("File")}} オブジェクトとして指定された、ユーザーが選択したすべてのファイルをリストアップします。ファイルリストの `length` 属性の値をチェックすることで、ユーザーが選択したファイルの数を知ることができます。
-<pre class="brush: js notranslate">const numFiles = fileList.length;</pre>
+```js
+const numFiles = fileList.length;
+```
-<p>個々の {{DOMxRef("File")}} オブジェクトは、単に配列としてリストにアクセスするだけで取得できます。</p>
+個々の {{DOMxRef("File")}} オブジェクトは、単に配列としてリストにアクセスするだけで取得できます。
-<pre class="brush: js notranslate">for (let i = 0, numFiles = fileList.length; i &lt; numFiles; i++) {
+```js
+for (let i = 0, numFiles = fileList.length; i < numFiles; i++) {
const file = fileList[i];
// ...
}
-</pre>
-
-<p>このループは、ファイルリスト内のすべてのファイルを繰り返し処理します。</p>
-
-<p>{{DOMxRef("File")}} オブジェクトには3つのプロパティがあり、ファイルに関する有益な情報を得られます。</p>
-
-<dl>
- <dt><code>name</code></dt>
- <dd>読み取り専用の文字列としてのファイル名。これはファイル名のみで、パスに関する情報は含まれていません。</dd>
- <dt><code>size</code></dt>
- <dd>読み取り専用の64ビット整数によるバイト単位のファイルサイズです。</dd>
- <dt><code>type</code></dt>
- <dd>読み取り専用の文字列としてのファイルの MIME タイプ (読み取り専用)。MIME タイプが特定できないときは空文字列 (<code>""</code>) となります。</dd>
-</dl>
-
-<h3 id="Example_Showing_files_size" name="Example_Showing_files_size">例: ファイルサイズを表示</h3>
-
-<p>次のコードは <code>size</code> プロパティを利用する例です。</p>
-
-<pre class="brush: html notranslate">&lt;!DOCTYPE html&gt;
-&lt;html&gt;
-&lt;head&gt;
- &lt;meta charset="UTF-8"&gt;
- &lt;title&gt;File(s) size&lt;/title&gt;
-&lt;/head&gt;
-
-&lt;body&gt;
- &lt;form name="uploadForm"&gt;
- &lt;div&gt;
- &lt;input id="uploadInput" type="file" name="myFiles" multiple&gt;
- 選択されたファイル: &lt;span id="fileNum"&gt;0&lt;/span&gt;;
- 合計サイズ: &lt;span id="fileSize"&gt;0&lt;/span&gt;
- &lt;/div&gt;
- &lt;div&gt;&lt;input type="submit" value="Send file"&gt;&lt;/div&gt;
- &lt;/form&gt;
-
- &lt;script&gt;
+```
+
+このループは、ファイルリスト内のすべてのファイルを繰り返し処理します。
+
+{{DOMxRef("File")}} オブジェクトには 3 つのプロパティがあり、ファイルに関する有益な情報を得られます。
+
+- `name`
+ - : 読み取り専用の文字列としてのファイル名。これはファイル名のみで、パスに関する情報は含まれていません。
+- `size`
+ - : 読み取り専用の 64 ビット整数によるバイト単位のファイルサイズです。
+- `type`
+ - : 読み取り専用の文字列としてのファイルの MIME タイプです。MIME タイプが特定できないときは空文字列 (`""`) となります。
+
+### 例: ファイルサイズを表示
+
+次のコードは `size` プロパティを利用する例です。
+
+```html
+<!DOCTYPE html>
+<html>
+<head>
+ <meta charset="UTF-8">
+ <title>ファイルのサイズ</title>
+</head>
+
+<body>
+ <form name="uploadForm">
+ <div>
+ <input id="uploadInput" type="file" name="myFiles" multiple>
+ 選択されたファイル: <span id="fileNum">0</span>;
+ 合計サイズ: <span id="fileSize">0</span>
+ </div>
+ <div><input type="submit" value="Send file"></div>
+ </form>
+
+ <script>
function updateSize() {
let nBytes = 0,
oFiles = this.files,
nFiles = oFiles.length;
- for (let nFileId = 0; nFileId &lt; nFiles; nFileId++) {
+ for (let nFileId = 0; nFileId < nFiles; nFileId++) {
nBytes += oFiles[nFileId].size;
}
let sOutput = nBytes + " bytes";
// 倍数近似のための任意のコード
const aMultiples = ["KiB", "MiB", "GiB", "TiB", "PiB", "EiB", "ZiB", "YiB"];
- for (nMultiple = 0, nApprox = nBytes / 1024; nApprox &gt; 1; nApprox /= 1024, nMultiple++) {
+ for (nMultiple = 0, nApprox = nBytes / 1024; nApprox > 1; nApprox /= 1024, nMultiple++) {
sOutput = nApprox.toFixed(3) + " " + aMultiples[nMultiple] + " (" + nBytes + " bytes)";
}
// 任意コードの末尾
@@ -108,23 +116,26 @@ function handleFiles() {
}
document.getElementById("uploadInput").addEventListener("change", updateSize, false);
- &lt;/script&gt;
-&lt;/body&gt;
-&lt;/html&gt;
-</pre>
+ </script>
+</body>
+</html>
+```
-<h2 id="Using_hidden_file_input_elements_using_the_click_method" name="Using_hidden_file_input_elements_using_the_click_method">click() メソッドを使い input 要素を隠す</h2>
+## click() メソッドを使用して非表示の input 要素を使用する
-<p>見た目の悪い {{HTMLElement("input")}} 要素を隠し、独自のインターフェイスでファイル選択を開き、ユーザーが選択したファイルを表示することができます。 input 要素のスタイルを <code>display: none</code> とし、その上で {{DOMxRef("HTMLElement.click","click()")}} メソッドを {{HTMLElement("input")}} に対して呼び出すことで実現できます。</p>
+見た目の悪い {{HTMLElement("input")}} 要素を非表示にし、独自のインターフェイスでファイル選択を開き、ユーザーが選択したファイルを表示することができます。 input 要素のスタイルを `display: none` とし、その上で {{DOMxRef("HTMLElement.click","click()")}} メソッドを {{HTMLElement("input")}} に対して呼び出すことで実現できます。
-<p>次のような HTML を考えてみましょう。</p>
+次のような HTML を考えてみましょう。
-<pre class="brush: html notranslate">&lt;input type="file" id="fileElem" multiple accept="image/*" style="display:none"&gt;
-&lt;button id="fileSelect"&gt;いくつかのファイルを選択します。&lt;/button&gt;</pre>
+```html
+<input type="file" id="fileElem" multiple accept="image/*" style="display:none">
+<button id="fileSelect">いくつかのファイルを選択してください。</button>
+```
-<p><code>click</code> イベントを扱うコードは次のようなものです。</p>
+`click` イベントを扱うコードは次のようなものです。
-<pre class="brush: js notranslate">const fileSelect = document.getElementById("fileSelect"),
+```js
+const fileSelect = document.getElementById("fileSelect"),
fileElem = document.getElementById("fileElem");
fileSelect.addEventListener("click", function (e) {
@@ -132,22 +143,25 @@ fileSelect.addEventListener("click", function (e) {
fileElem.click();
}
}, false);
-</pre>
+```
-<p>ファイル選択を開く新しいボタンは、好きなようにスタイル付けできます。</p>
+ファイル選択を開くための新しいボタンは、好きなようにスタイル付けできます。
-<h2 id="Using_a_label_element_to_trigger_a_hidden_file_input_element" name="Using_a_label_element_to_trigger_a_hidden_file_input_element">label 要素を使用して隠した file input 要素を起動</h2>
+## label 要素を使用して非表示の file input 要素を起動
-<p>JavaScript (click() メソッド) を使用せずにファイルピッカーを開けるようにするために、 {{HTMLElement("label")}} 要素を使用します。この場合、もし入力エレメントの <code>display: none</code> (または <code>visibility: hidden</code>) を設定して非表示に設定すると、ラベルがキーボードからアクセスできなくなります。代わりに、視覚的に非表示にする手法 (<a href="https://a11yproject.com/posts/how-to-hide-content/">visually-hidden technique</a>) を使用します。</p>
+JavaScript (click() メソッド) を使用せずにファイル選択を開けるようにするために、 {{HTMLElement("label")}} 要素を使用します。この場合、 input 要素に `display: none` (または `visibility: hidden`) を設定して非表示に設定すると、ラベルがキーボードからアクセスできなくなります。代わりに、視覚的に非表示にする手法 ([visually-hidden technique](https://a11yproject.com/posts/how-to-hide-content/)) を使用します。
-<p>次の HTMLを見てください。</p>
+次の HTML を見てください。
-<pre class="brush: html notranslate">&lt;input type="file" id="fileElem" multiple accept="image/*" class="visually-hidden"&gt;
-&lt;label for="fileElem"&gt;いくつかのファイルを選択します。&lt;/label&gt;</pre>
+```html
+<input type="file" id="fileElem" multiple accept="image/*" class="visually-hidden">
+<label for="fileElem">いくつかのファイルを選択してください。</label>
+```
-<p>そしてこの CSS です。</p>
+そしてこの CSS です。
-<pre class="brush: css notranslate">.visually-hidden {
+```css
+.visually-hidden {
position: absolute !important;
height: 1px;
width: 1px;
@@ -162,29 +176,31 @@ input.visually-hidden:focus + label {
input.visually-hidden:focus-within + label {
outline: thin dotted;
}
-</pre>
+```
-<p><code>fileElem.click()</code>を呼び出すための JavaScript コードを追加する必要はありません。またこの場合は、ラベル要素のスタイルを希望どおりに設定することもできます。前例のようにアウトラインに設定したり、background-color、box-shadow を設定したりして、ラベルの非表示入力フィールドのフォーカスステータスを視覚的に示す必要があります。(この記事を書いている時点では、Firefox は<code>&lt;input type="file"&gt;</code> 要素に対してこの視覚的な手がかりを表示していません)</p>
+JavaScript コードを追加して `fileElem.click()` を呼び出す必要はありません。またこの場合は、ラベル要素のスタイルを希望どおりに設定することもできます。前例のようにアウトラインに設定したり、background-color や box-shadow を設定したりして、ラベルの非表示入力フィールドのフォーカスステータスを視覚的に示す必要があります。(この記事を書いている時点では、Firefox は `<input type="file">` 要素に対してこの視覚的な手がかりを表示していません。)
-<h2 id="Selecting_files_using_drag_and_drop" name="Selecting_files_using_drag_and_drop">ドラッグ &amp; ドロップを使用したファイルの選択</h2>
+## ドラッグ&ドロップを使用したファイルの選択
-<p>ユーザーがファイルをウェブアプリケーションにドラッグ &amp; ドロップすることもできます。</p>
+ユーザーがファイルをウェブアプリケーションにドラッグ&ドロップすることもできます。
-<p>最初のステップは、ドロップゾーンを確立することです。コンテンツのどの部分がドロップを受け入れるかは、アプリケーションの設計によって異なりますが、要素をドロップイベントを受け取るのは簡単です。</p>
+最初のステップは、ドロップゾーンを確立することです。コンテンツのどの部分がドロップを受け入れるかは、アプリケーションの設計によって異なりますが、要素をドロップイベントを受け取るのは簡単です。
-<pre class="brush: js notranslate">let dropbox;
+```js
+let dropbox;
dropbox = document.getElementById("dropbox");
dropbox.addEventListener("dragenter", dragenter, false);
dropbox.addEventListener("dragover", dragover, false);
dropbox.addEventListener("drop", drop, false);
-</pre>
+```
-<p>この例では、ID <code>dropbox</code> を持つ要素をドロップゾーンに指定しています。これは、{{event('dragenter')}}、{{event('dragover')}}、および {{event('drop')}} イベントのリスナーを追加することで行われます。</p>
+この例では、ID `dropbox` を持つ要素をドロップゾーンに指定しています。これは、{{domxref('Document/dragenter_event', 'dragenter')}}、{{domxref('Document/dragover_event', 'dragover')}}、{{domxref('Document/drop_event', 'drop')}} の各イベントのリスナーを追加することで行われます。
-<p>実際には、この場合、<code>dragenter</code>と<code>dragover</code>のイベントでは何もする必要はありませんので、これらの関数はどちらも簡単です。これらの関数はイベントの伝播を停止し、デフォルトのアクションが発生しないようにするだけです。</p>
+実際には、この場合、 `dragenter` と `dragover` のイベントでは何もする必要はありませんので、これらの関数はどちらも簡単です。これらの関数はイベントの伝播を停止し、既定のアクションが発生しないようにするだけです。
-<pre class="brush: js notranslate">function dragenter(e) {
+```js
+function dragenter(e) {
e.stopPropagation();
e.preventDefault();
}
@@ -193,11 +209,12 @@ function dragover(e) {
e.stopPropagation();
e.preventDefault();
}
-</pre>
+```
-<p>本当の魔術は <code>drop()</code> 関数の中で起こります。</p>
+本当の魔法は `drop()` 関数の中で起こります。
-<pre class="brush: js notranslate">function drop(e) {
+```js
+function drop(e) {
e.stopPropagation();
e.preventDefault();
@@ -206,16 +223,17 @@ function dragover(e) {
handleFiles(files);
}
-</pre>
+```
-<p>ここでは、イベントから <code>dataTransfer</code> フィールドを取得し、そこからファイルリストを取得し、それを <code>handleFiles()</code> に渡します。これより先は、ユーザーが入力要素を使用したかドラッグ &amp; ドロップを使用するかどうかにかかわらず、ファイルの処理方法は全く同じです。</p>
+ここでは、イベントから `dataTransfer` フィールドを取得し、そこからファイルリストを取得し、それを `handleFiles()` に渡します。これより先は、ユーザーが入力要素を使用したかドラッグ&ドロップを使用するかどうかにかかわらず、ファイルの処理方法は全く同じです。
-<h2 id="Example_Showing_thumbnails_of_user-selected_images" name="Example_Showing_thumbnails_of_user-selected_images">例: ユーザが選択した画像のサムネイルを表示</h2>
+## 例: ユーザーが選択した画像のサムネイルを表示
-<p>次の素晴らしい写真共有サイトを開発していて、ユーザーが実際に画像をアップロードする前に HTML を使って画像のサムネイルプレビューを表示させたいとしましょう。前に説明したように <code>input</code> 要素やドロップゾーンを設定し、次の <code>handleFiles()</code> のような関数を呼び出せば良いのです。</p>
+次の素晴らしい写真共有サイトを開発していて、ユーザーが実際に画像をアップロードする前に HTML を使って画像のサムネイルプレビューを表示させたいとしましょう。前に説明したように `input` 要素やドロップゾーンを設定し、次の `handleFiles()` のような関数を呼び出せば良いのです。
-<pre class="brush: js notranslate">function handleFiles(files) {
- for (let i = 0; i &lt; files.length; i++) {
+```js
+function handleFiles(files) {
+ for (let i = 0; i < files.length; i++) {
const file = files[i];
if (!file.type.startsWith('image/')){ continue }
@@ -230,44 +248,50 @@ function dragover(e) {
reader.readAsDataURL(file);
}
}
-</pre>
+```
-<p>ここでは、ユーザーが選択したファイルを処理するループが各ファイルの <code>type</code> 属性を見て、その MIME タイプが文字列 "image/" で始まるかどうかを確認しています)。画像である各ファイルに対して、新しい <code>img</code> 要素を作成します。CSS は、きれいな境界線や影を設定したり、画像のサイズを指定したりするために使用しますので、ここでは必要ありません。</p>
+ここでは、ユーザーが選択したファイルを処理するループが各ファイルの `type` 属性を見て、その MIME タイプが "`image/`" という文字列で始まるかどうかを確認しています。画像である各ファイルに対して、新しい `img` 要素を作成します。CSS は、きれいな境界線や影を設定したり、画像のサイズを指定したりするために使用しますので、ここでは必要ありません。
-<p>各画像には CSS クラス <code>obj</code> が追加されており、DOM ツリーで簡単に見つけることができます。また、各画像に <code>file</code> 属性を追加し、画像の {{DOMxRef("File")}} を指定しています。これにより、後で実際にアップロードする画像を取得することができます。{{DOMxRef("Node.appendChild()")}} を使用して、ドキュメントのプレビュー領域に新しいサムネイルを追加します。</p>
+各画像には CSS クラス `obj` が追加されており、DOM ツリーで簡単に見つけることができます。また、各画像に `file` 属性を追加し、画像の {{DOMxRef("File")}} を指定しています。これにより、後で実際にアップロードする画像を取得することができます。{{DOMxRef("Node.appendChild()")}} を使用して、文書のプレビュー領域に新しいサムネイルを追加します。
-<p>次に、画像の読み込みと <code>img</code> 要素へのアタッチを非同期で処理するための {{DOMxRef("FileReader")}} を確立します。新しい <code>FileReader</code> オブジェクトを作成した後、その <code>onload</code> 関数を設定し、<code>readAsDataURL()</code> を呼び出してバックグラウンドで読み込み処理を開始します。画像ファイルのコンテンツ全体が読み込まれると、それらは <code>data:</code> URL に変換され、<code>onload</code> コールバックに渡されます。このルーチンの実装では、<code>img</code> 要素の <code>src</code> 属性が読み込まれた画像に設定され、その結果、画像がユーザの画面のサムネイルに表示されます。</p>
+次に、画像の読み込みと `img` 要素へのアタッチを非同期で処理するための {{DOMxRef("FileReader")}} を確立します。新しい `FileReader` オブジェクトを作成した後、その `onload` 関数を設定し、`readAsDataURL()` を呼び出してバックグラウンドで読み込み処理を開始します。画像ファイルのコンテンツ全体が読み込まれると、それらは `data:` URL に変換され、`onload` コールバックに渡されます。このルーチンの実装では、`img` 要素の `src` 属性が読み込まれた画像に設定され、その結果、画像がユーザの画面のサムネイルに表示されます。
-<h2 id="Using_object_URLs" name="Using_object_URLs">オブジェクト URL を利用する</h2>
+## オブジェクト URL を利用する
-<p>DOM {{DOMxRef("URL.createObjectURL()")}} と {{DOMxRef("URL.revokeObjectURL()")}} メソッドを使用すると、ユーザーのコンピューター上のローカルファイルなど、DOM {{DOMxRef("File")}} オブジェクトを使用して参照可能なあらゆるデータを参照するために使用できるシンプルな URL 文字列を作成できます。</p>
+DOM の {{DOMxRef("URL.createObjectURL()")}} と {{DOMxRef("URL.revokeObjectURL()")}} メソッドを使用すると、ユーザーのコンピューター上のローカルファイルなど、DOM {{DOMxRef("File")}} オブジェクトを使用して参照可能なあらゆるデータを参照するために使用できるシンプルな URL 文字列を作成できます。
-<p>HTML から URL で参照したい {{DOMxRef("File")}} オブジェクトがある場合は、次のようにオブジェクト URL を作成します。</p>
+HTML から URL で参照したい {{DOMxRef("File")}} オブジェクトがある場合は、次のようにオブジェクト URL を作成します。
-<pre class="brush: js notranslate">const objectURL = window.URL.createObjectURL(fileObj);</pre>
+```js
+const objectURL = window.URL.createObjectURL(fileObj);
+```
-<p>オブジェクト URL は {{DOMxRef("File")}} オブジェクトを識別する文字列です。 {{DOMxRef("URL.createObjectURL()")}} を呼び出すたびに、すでにそのファイルのオブジェクト URL を作成していても、一意のオブジェクト URL が作成されます。これらはそれぞれ解除する必要があります。これらはドキュメントがアンロードされると自動的に解放されますが、ページが動的にこれらを使用している場合は {{DOMxRef("URL.revokeObjectURL()")}} を呼び出して明示的に解放する必要があります。</p>
+オブジェクト URL は {{DOMxRef("File")}} オブジェクトを識別する文字列です。 {{DOMxRef("URL.createObjectURL()")}} を呼び出すたびに、すでにそのファイルのオブジェクト URL を作成していても、一意のオブジェクト URL が作成されます。これらはそれぞれ解除する必要があります。これらはドキュメントがアンロードされると自動的に解放されますが、ページが動的にこれらを使用している場合は {{DOMxRef("URL.revokeObjectURL()")}} を呼び出して明示的に解放する必要があります。
-<pre class="brush: js notranslate">URL.revokeObjectURL(objectURL);</pre>
+```js
+URL.revokeObjectURL(objectURL);
+```
-<h2 id="Example_Using_object_URLs_to_display_images" name="Example:_Using_object_URLs_to_display_images">例: オブジェクト URL で画像を表示</h2>
+## 例: オブジェクト URL で画像を表示
-<p>この例では、オブジェクト URL を使用して画像のサムネイルを表示しています。さらに、ファイル名やサイズなどの他のファイル情報も表示します。</p>
+この例では、オブジェクト URL を使用して画像のサムネイルを表示しています。さらに、ファイル名やサイズなどの他のファイル情報も表示します。
-<p>インターフェースとなる HTML は次のようになります。</p>
+インターフェースとなる HTML は次のようになります。
-<pre class="brush: html notranslate">&lt;input type="file" id="fileElem" multiple accept="image/*" style="display:none"&gt;
-&lt;a href="#" id="fileSelect"&gt;いくつかのファイルを選択します。&lt;/a&gt;
-&lt;div id="fileList"&gt;
- &lt;p&gt;選択されたファイルはありません!&lt;/p&gt;
-&lt;/div&gt;
-</pre>
+```html
+<input type="file" id="fileElem" multiple accept="image/*" style="display:none">
+<a href="#" id="fileSelect">いくつかのファイルを選択してください。</a>
+<div id="fileList">
+ <p>ファイルが選択されていません。</p>
+</div>
+```
-<p>これにより、ファイル {{HTMLElement("input")}} 要素と、ファイル ピッカーを呼び出すリンクが確立されます (あまり美しくないファイル入力を非表示にするため)。これは、ファイル ピッカーを呼び出すメソッドと同様に、セクション {{anch("click() メソッドを使用して非表示のファイル入力要素を使用する")}} で説明されています。</p>
+これにより、ファイル {{HTMLElement("input")}} 要素と、ファイル選択を呼び出すリンクが確立されます (あまり美しくないファイル入力を非表示にするため)。これは、ファイル選択を呼び出すメソッドと同様に、セクション {{anch("click_%E3%83%A1%E3%82%BD%E3%83%83%E3%83%89%E3%82%92%E4%BD%BF%E7%94%A8%E3%81%97%E3%81%A6%E9%9D%9E%E8%A1%A8%E7%A4%BA%E3%81%AE_input_%E8%A6%81%E7%B4%A0%E3%82%92%E4%BD%BF%E7%94%A8%E3%81%99%E3%82%8B", "click() メソッドを使用して非表示の input 要素を使用する")}} で説明されています。
-<p><code>handleFiles()</code> メソッドは次のようになります。</p>
+`handleFiles()` メソッドは次のようになります。
-<pre class="brush: js notranslate">const fileSelect = document.getElementById("fileSelect"),
+```js
+const fileSelect = document.getElementById("fileSelect"),
fileElem = document.getElementById("fileElem"),
fileList = document.getElementById("fileList");
@@ -282,12 +306,12 @@ fileElem.addEventListener("change", handleFiles, false);
function handleFiles() {
if (!this.files.length) {
- fileList.innerHTML = "&lt;p&gt;ファイルが選択されていません!&lt;/p&gt;";
+ fileList.innerHTML = "<p>ファイルが選択されていません。</p>";
} else {
fileList.innerHTML = "";
const list = document.createElement("ul");
fileList.appendChild(list);
- for (let i = 0; i &lt; this.files.length; i++) {
+ for (let i = 0; i < this.files.length; i++) {
const li = document.createElement("li");
list.appendChild(li);
@@ -299,60 +323,58 @@ function handleFiles() {
}
li.appendChild(img);
const info = document.createElement("span");
- info.innerHTML = this.files[i].name + ": " + this.files[i].size + " bytes";
+ info.innerHTML = this.files[i].name + ": " + this.files[i].size + " バイト";
li.appendChild(info);
}
}
}
-</pre>
+```
+
+これは、{{HTMLElement("div")}} の URL を `fileList` という ID で取得することから始まります。これは、サムネイルを含むファイルリストを挿入するブロックです。
-<p>これは、{{HTMLElement("div")}} の URL を <code>fileList</code> という ID で取得することから始まります。これは、サムネイルを含むファイルリストを挿入するブロックです。</p>
+`handleFiles()` に渡された {{DOMxRef("FileList")}} オブジェクトが `null` の場合、ブロックの内部 HTML に「ファイルが選択されていません」と表示するように設定します。そうでない場合は、次のようにファイルリストの構築を開始します。
-<p><code>handleFiles()</code> に渡された {{DOMxRef("FileList")}} オブジェクトが <code>null</code> の場合、ブロックの内部 HTML に「ファイルが選択されていません」と表示するように設定します。そうでない場合は、次のようにファイルリストの構築を開始します。</p>
+1. 新しく順序なしリスト ({{HTMLElement("ul")}}) 要素を作成します。
+2. 新しいリスト要素は、{{HTMLElement("div")}} ブロックの中に {{DOMxRef("Node.appendChild()")}} メソッドを呼び出すことで挿入されます。
+3. `files` で表される {{DOMxRef("FileList")}} 内のそれぞれの {{DOMxRef("File")}} に対して次の処理を実行します。
-<ol>
- <li>新しく順序なしリスト ({{HTMLElement("ul")}}) 要素を作成します</li>
- <li>新しいリスト要素は、{{HTMLElement("div")}} ブロックの {{DOMxRef("Node.appendChild()")}} メソッドを呼び出して {{HTMLElement("div")}} ブロックに挿入されます</li>
- <li><code>files</code> で表される {{DOMxRef("FileList")}} 内の各 {{DOMxRef("File")}} に対して次の処理を実行します
- <ol>
- <li>新しくリスト項目 ({{HTMLElement("li")}}) 要素を作成し、リストに挿入します</li>
- <li>新しく画像 ({{HTMLElement("img")}}) 要素を作成します</li>
- <li>{{DOMxRef("URL.createObjectURL()")}} を用いて、Blob の URL を作成して、画像のソースをファイルを表す新しいオブジェクト URL に設定します</li>
- <li>画像の高さを60ピクセルに設定します</li>
- <li>画像が読み込まれると不要になるため、画像の読み込みイベントハンドラを設定してオブジェクトの URL を解放します。これは {{DOMxRef("URL.revokeObjectURL()")}} メソッドを呼び出し、<code>img.src</code> で指定したオブジェクト URL 文字列を渡すことで行います</li>
- <li>新しいリスト項目をリストに追加する</li>
- </ol>
- </li>
-</ol>
+ 1. 新しくリスト項目 ({{HTMLElement("li")}}) 要素を作成し、リストに挿入します。
+ 2. 新しく画像 ({{HTMLElement("img")}}) 要素を作成します。
+ 3. {{DOMxRef("URL.createObjectURL()")}} を用いて、Blob の URL を作成して、画像のソースをファイルを表す新しいオブジェクト URL に設定します。
+ 4. 画像の高さを 60 ピクセルに設定します。
+ 5. 画像が読み込まれると不要になるため、画像の読み込みイベントハンドラーを設定してオブジェクトの URL を解放します。これは {{DOMxRef("URL.revokeObjectURL()")}} メソッドを呼び出し、`img.src` で指定したオブジェクト URL 文字列を渡すことで行います。
+ 6. 新しいリスト項目をリストに追加する。
-<p>上のコードのライブデモはこちらです。</p>
+上のコードのライブデモはこちらです。
-<p>{{EmbedLiveSample('Example_Using_object_URLs_to_display_images', '100%', '300px')}}</p>
+{{EmbedLiveSample('Example_Using_object_URLs_to_display_images', '100%', '300px')}}
-<h2 id="Example_Uploading_a_user-selected_file" name="Example:_Uploading_a_user-selected_file">例: ユーザが選択したファイルを送信</h2>
+## 例: ユーザが選択したファイルを送信
-<p>もう1つは、ユーザーが選択したファイルやファイル (先ほどの例で選択した画像など) をサーバーにアップロードできるようにすることです。これは非常に簡単に非同期で行うことができます。</p>
+もう1つは、ユーザーが選択したファイルやファイル (先ほどの例で選択した画像など) をサーバーにアップロードできるようにすることです。これは非常に簡単に非同期で行うことができます。
-<h3 id="Creating_the_upload_tasks" name="Creating_the_upload_tasks">アップロードタスクの生成</h3>
+### アップロードタスクの生成
-<p>前の例でサムネイルを作成したコードの続きで、すべてのサムネイル画像が CSS クラス <code>obj</code> にあり、対応する {{DOMxRef("File")}}} が <code>file</code> 属性に添付されていることを思い出してください。これにより、このように{{DOMxRef("Document.querySelectorAll()")}}を使用して、ユーザーがアップロードするために選択した画像をすべて選択することができます。</p>
+前の例でサムネイルを作成したコードの続きで、すべてのサムネイル画像が CSS クラス `obj` にあり、対応する {{DOMxRef("File")}}} が `file` 属性に添付されていることを思い出してください。これにより、このように{{DOMxRef("Document.querySelectorAll()")}}を使用して、ユーザーがアップロードするために選択した画像をすべて選択することができます。
-<pre class="brush: js notranslate">function sendFiles() {
+```js
+function sendFiles() {
const imgs = document.querySelectorAll(".obj");
- for (let i = 0; i &lt; imgs.length; i++) {
+ for (let i = 0; i < imgs.length; i++) {
new FileUpload(imgs[i], imgs[i].file);
}
}
-</pre>
+```
-<p>2 行目は、CSS クラス <code>obj</code> を持つドキュメント内のすべての要素の {{DOMxRef("NodeList")}}} を取得し <code>imgs</code> と呼ばれる変数に格納します。この例では、これらの要素はすべての画像サムネイルになります。このリストを取得したら、それを参照して、それぞれの新しい <code>FileUpload</code> インスタンスを作成するのは簡単です。それぞれが対応するファイルのアップロードを処理します。</p>
+2 行目は、CSS クラス `obj` を持つドキュメント内のすべての要素の {{DOMxRef("NodeList")}}} を取得し `imgs` と呼ばれる変数に格納します。この例では、これらの要素はすべての画像サムネイルになります。このリストを取得したら、それを参照して、それぞれの新しい `FileUpload` インスタンスを作成するのは簡単です。それぞれが対応するファイルのアップロードを処理します。
-<h3 id="Handling_the_upload_process_for_a_file" name="Handling_the_upload_process_for_a_file">ファイルのアップロード処理を行う</h3>
+### ファイルのアップロード処理を行う
-<p><code>FileUpload</code> 関数は2つの入力、画像要素と画像データを読み込むファイルを受け付けます。</p>
+`FileUpload` 関数は 2 つの入力、画像要素と画像データを読み込むファイルを受け付けます。
-<pre class="brush: js notranslate">function FileUpload(img, file) {
+```js
+function FileUpload(img, file) {
const reader = new FileReader();
this.ctrl = createThrobber(img);
const xhr = new XMLHttpRequest();
@@ -378,37 +400,36 @@ function handleFiles() {
};
reader.readAsBinaryString(file);
}
-</pre>
+```
-<p>上の <code>FileUpload()</code> 関数は、進捗情報を表示するための throbber を作成し、データのアップロードを処理するための {{DOMxRef("XMLHttpRequest")}} を作成します。</p>
+上の `FileUpload()` 関数は、進捗情報を表示するための throbber を作成し、データのアップロードを処理するための {{DOMxRef("XMLHttpRequest")}} を作成します。
-<p>実際にデータを転送する前に、いくつかの準備段階があります。</p>
+実際にデータを転送する前に、いくつかの準備段階があります。
-<ol>
- <li><code>XMLHttpRequest</code> のアップロード <code>progress</code> リスナーは、アップロードの進捗に応じて最新の情報に基づいて throbber が更新されるように、新しいパーセンテージ情報で throbber を更新するように設定されています</li>
- <li><code>XMLHttpRequest</code> のアップロード <code>load</code> イベントハンドラは、進捗インジケータが実際に 100 % に達することを確認するために、throbber の進捗情報を 100 % に更新するように設定されています (プロセス中に粒度のクセがある場合)。そして、必要がなくなれば throbber を削除します。これにより、アップロードが完了すると throbber が消えます</li>
- <li>画像ファイルをアップロードするリクエストは、<code>XMLHttpRequest</code> の <code>open()</code> メソッドを呼び出して POST リクエストを生成することで開始されます</li>
- <li>アップロードの MIME タイプは <code>XMLHttpRequest</code> 関数の <code>overrideMimeType()</code> を呼び出して設定します。この場合、一般的な MIME タイプを使用しています。ユースケースによっては MIME タイプを設定する必要がない場合もあります</li>
- <li><code>FileReader</code> オブジェクトを使用して、ファイルをバイナリ文字列に変換します</li>
- <li>最後に、コンテンツがロードされると、<code>XMLHttpRequest</code> 関数の <code>send()</code> が呼び出され、ファイルのコンテンツがアップロードされます</li>
-</ol>
+1. `XMLHttpRequest` のアップロード `progress` リスナーは、アップロードの進捗に応じて最新の情報に基づいて throbber が更新されるように、新しいパーセント値の情報で throbber を更新するように設定されています。
+2. `XMLHttpRequest` のアップロード `load` イベントハンドラーは、進捗インジケーターが実際に 100 % に達することを確認するために、throbber の進捗情報を 100% に更新するように設定されています (プロセス中に粒度のクセがある場合)。そして、必要がなくなれば throbber を削除します。これにより、アップロードが完了すると throbber が消えます。
+3. 画像ファイルをアップロードするリクエストは、`XMLHttpRequest` の `open()` メソッドを呼び出して POST リクエストを生成することで開始されます。
+4. アップロードの MIME タイプは `XMLHttpRequest` 関数の `overrideMimeType()` を呼び出して設定します。この場合、一般的な MIME タイプを使用しています。用途によっては MIME タイプを設定する必要がない場合もあります。
+5. `FileReader` オブジェクトを使用して、ファイルをバイナリー文字列に変換します
+6. 最後に、コンテンツがロードされると、 `XMLHttpRequest` 関数の `send()` が呼び出され、ファイルのコンテンツがアップロードされます。
-<h3 id="Asynchronously_handling_the_file_upload_process" name="Asynchronously_handling_the_file_upload_process">ファイルのアップロード処理を非同期に扱う</h3>
+### ファイルのアップロード処理を非同期に扱う
-<p>この例では、サーバー側で PHP を使用し、クライアント側で JavaScript を使用して、ファイルの非同期アップロードを実演しています。</p>
+この例では、サーバー側で PHP を使用し、クライアント側で JavaScript を使用して、ファイルの非同期アップロードを実演しています。
-<pre class="brush: js notranslate">&lt;?php
+```js
+<?php
if (isset($_FILES['myFile'])) {
// 例:
move_uploaded_file($_FILES['myFile']['tmp_name'], "uploads/" . $_FILES['myFile']['name']);
exit;
}
-?&gt;&lt;!DOCTYPE html&gt;
-&lt;html&gt;
-&lt;head&gt;
- &lt;title&gt;dnd binary upload&lt;/title&gt;
- &lt;meta http-equiv="Content-Type" content="text/html; charset=UTF-8"&gt;
- &lt;script type="application/javascript"&gt;
+?><!DOCTYPE html>
+<html>
+<head>
+ <title>dnd binary upload</title>
+ <meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
+ <script type="application/javascript">
function sendFile(file) {
const uri = "/index.php";
const xhr = new XMLHttpRequest();
@@ -416,7 +437,7 @@ if (isset($_FILES['myFile'])) {
xhr.open("POST", uri, true);
xhr.onreadystatechange = function() {
- if (xhr.readyState == 4 &amp;&amp; xhr.status == 200) {
+ if (xhr.readyState == 4 && xhr.status == 200) {
alert(xhr.responseText); // handle response.
}
};
@@ -437,78 +458,83 @@ if (isset($_FILES['myFile'])) {
event.preventDefault();
const filesArray = event.dataTransfer.files;
- for (let i=0; i&lt;filesArray.length; i++) {
+ for (let i=0; i<filesArray.length; i++) {
sendFile(filesArray[i]);
}
}
}
- &lt;/script&gt;
-&lt;/head&gt;
-&lt;body&gt;
- &lt;div&gt;
- &lt;div id="dropzone" style="margin:30px; width:500px; height:300px; border:1px dotted grey;"&gt;Drag &amp; drop your file here...&lt;/div&gt;
- &lt;/div&gt;
-&lt;/body&gt;
-&lt;/html&gt;
-</pre>
+ </script>
+</head>
+<body>
+ <div>
+ <div id="dropzone" style="margin:30px; width:500px; height:300px; border:1px dotted grey;">Drag & drop your file here...</div>
+ </div>
+</body>
+</html>
+```
-<h2 id="Example_Using_object_URLs_to_display_PDF" name="Example_Using_object_URLs_to_display_PDF">例: オブジェクト URL を使用して PDF を表示</h2>
+## 例: オブジェクト URL を使用して PDF を表示
-<p>オブジェクト URL は画像以外にも使用できます。埋め込まれた PDF ファイルや、ブラウザーで表示可能な他のリソースを表示するために使用できます。</p>
+オブジェクト URL は画像以外にも使用できます。埋め込まれた PDF ファイルや、ブラウザーで表示可能な他のリソースを表示するために使用できます。
-<p>Firefox では、 PDF が iframe 内に埋め込まれて表示されるようにするには (ダウンロードファイルとして提案されるのではなく)、<code>pdfjs.disabled</code> の設定を <code>false</code> {{non-standard_inline()}} に設定する必要があります。</p>
+Firefox では、 PDF が iframe 内に埋め込まれて表示されるようにするには (ダウンロードファイルとして提案されるのではなく)、`pdfjs.disabled` の設定を `false` {{non-standard_inline()}} に設定する必要があります。
-<pre class="brush: html notranslate">&lt;iframe id="viewer"&gt;
-</pre>
+```html
+<iframe id="viewer">
+```
-<p>そして、<code>src</code> 属性の変更点はこちらです。</p>
+そして、`src` 属性の変更点はこちらです。
-<pre class="brush: js notranslate">const obj_url = URL.createObjectURL(blob);
+```js
+const obj_url = URL.createObjectURL(blob);
const iframe = document.getElementById('viewer');
iframe.setAttribute('src', obj_url);
-URL.revokeObjectURL(obj_url);</pre>
+URL.revokeObjectURL(obj_url);
+```
-<h2 id="Example_Using_object_URLs_with_other_file_types" name="Example_Using_object_URLs_with_other_file_types">例: 他のファイル形式でのオブジェクト URL の使用</h2>
+## 例: 他のファイル形式でのオブジェクト URL の使用
-<p>他の形式のファイルも同じように操作できます。ここでは、アップロードされた動画をプレビューする方法を紹介します。</p>
+他の形式のファイルも同じように操作できます。ここでは、アップロードされた動画をプレビューする方法を紹介します。
-<pre class="brush: js notranslate">const video = document.getElementById('video');
+```js
+const video = document.getElementById('video');
const obj_url = URL.createObjectURL(blob);
video.src = obj_url;
video.play();
-URL.revokeObjectURL(obj_url);</pre>
-
-<h2 id="Specification" name="Specification">仕様書</h2>
-
-<table class="standard-table">
- <thead>
- <tr>
- <th scope="col">仕様書</th>
- <th scope="col">状態</th>
- <th scope="col">備考</th>
- </tr>
- </thead>
- <tbody>
- <tr>
- <td>{{SpecName('HTML WHATWG', 'number-state.html#concept-input-type-file-selected', 'File upload state')}}</td>
- <td>{{Spec2('HTML WHATWG')}}</td>
- <td></td>
- </tr>
- <tr>
- <td>{{SpecName('File API')}}</td>
- <td>{{Spec2('File API')}}</td>
- <td>初回定義</td>
- </tr>
- </tbody>
+URL.revokeObjectURL(obj_url);
+```
+
+## 仕様書
+
+<table class="no-markdown">
+ <thead>
+ <tr>
+ <th scope="col">仕様書</th>
+ <th scope="col">状態</th>
+ <th scope="col">備考</th>
+ </tr>
+ </thead>
+ <tbody>
+ <tr>
+ <td>
+ {{SpecName('HTML WHATWG', 'number-state.html#concept-input-type-file-selected', 'File upload state')}}
+ </td>
+ <td>{{Spec2('HTML WHATWG')}}</td>
+ <td></td>
+ </tr>
+ <tr>
+ <td>{{SpecName('File API')}}</td>
+ <td>{{Spec2('File API')}}</td>
+ <td>初回定義</td>
+ </tr>
+ </tbody>
</table>
-<h2 id="See_also" name="See_also">関連情報</h2>
+## 関連情報
-<ul>
- <li>{{DOMxRef("File")}}</li>
- <li>{{DOMxRef("FileList")}}</li>
- <li>{{DOMxRef("FileReader")}}</li>
- <li>{{DOMxRef("URL")}}</li>
- <li>{{DOMxRef("XMLHttpRequest")}}</li>
- <li><a href="/ja/docs/Web/API/XMLHttpRequest/Using_XMLHttpRequest">XMLHttpRequest の使用</a></li>
-</ul>
+- {{DOMxRef("File")}}
+- {{DOMxRef("FileList")}}
+- {{DOMxRef("FileReader")}}
+- {{DOMxRef("URL")}}
+- {{DOMxRef("XMLHttpRequest")}}
+- [XMLHttpRequest の使用](/ja/docs/Web/API/XMLHttpRequest/Using_XMLHttpRequest)