diff options
-rw-r--r-- | files/zh-cn/web/api/htmlinputelement/webkitdirectory/index.html | 142 |
1 files changed, 142 insertions, 0 deletions
diff --git a/files/zh-cn/web/api/htmlinputelement/webkitdirectory/index.html b/files/zh-cn/web/api/htmlinputelement/webkitdirectory/index.html new file mode 100644 index 0000000000..b05acb9413 --- /dev/null +++ b/files/zh-cn/web/api/htmlinputelement/webkitdirectory/index.html @@ -0,0 +1,142 @@ +--- +title: HTMLInputElement.webkitdirectory +slug: Web/API/HTMLInputElement/webkitdirectory +tags: +- API +- File System API +- File and Directory Entries API +- Files +- HTML DOM +- HTMLInputElement +- Non-standard +- Property +- Reference +- Web +- webkitdirectory +translation_of: Web/API/HTMLInputElement/webkitdirectory +--- +<p>{{APIRef("HTML DOM")}}{{non-standard_header}}</p> + +<p><span class="seoSummary"> + <code><strong>HTMLInputElement.webkitdirectory</strong></code>是属于{{HTMLElement("input")}}元素的一个HTML属性{{htmlattrxref("webkitdirectory", "input")}},它指示<code><input></code>元素应该允许用户选择文件目录,而不是文件。当一个文件目录被选中,该目录及其整个内容层次结构将包含在所选项目集里面。可以使用{{domxref("HTMLInputElement.webkitEntries", + "webkitEntries")}}属性获取选定的文件系统条目。</span></p> + +<h2 id="Syntax">语法</h2> + +<pre + class="brush: js"> <em>HTMLInputElement</em>.webkitdirectory = <em>boolValue</em></pre> + +<h3 id="Value">值</h3> + +<p>一个布尔值; 如果设置为<code>true</code>,则{{HTMLElement("input")}}元素只允许选择目录;如果设置为<code>false</code>,则只允许选择文件。</p> + +<h2 id="Understanding_the_results">了解结果</h2> + +<p>在用户进行选择后,<code>files</code>里的每个{{domxref("File")}}对象都会将其拥有的{{domxref("File.webkitRelativePath")}}属性设置为所选目录内文件所在的相对路径。例如,考虑以下文件系统:</p> + +<ul> + <li>PhotoAlbums + <ul> + <li>Birthdays + <ul> + <li>Jamie's 1st birthday + <ul> + <li>PIC1000.jpg</li> + <li>PIC1004.jpg</li> + <li>PIC1044.jpg</li> + </ul> + </li> + <li>Don's 40th birthday + <ul> + <li>PIC2343.jpg</li> + <li>PIC2344.jpg</li> + <li>PIC2355.jpg</li> + <li>PIC2356.jpg</li> + </ul> + </li> + </ul> + </li> + <li>Vacations + <ul> + <li>Mars + <ul> + <li>PIC5533.jpg</li> + <li>PIC5534.jpg</li> + <li>PIC5556.jpg</li> + <li>PIC5684.jpg</li> + <li>PIC5712.jpg</li> + </ul> + </li> + </ul> + </li> + </ul> + </li> +</ul> + +<p>如果用户选择了<code>PhotoAlbums</code>,则文件列表上将会包含上面列出的每个文件的{{domxref("File")}}对象,而不是文件目录。条目<code>PIC2343.jpg</code>的<code>webkitRelativePath</code>属性将会得到<code>PhotoAlbums/Birthdays/Don's 40th birthday/PIC2343.jpg</code>的值。即使{{domxref("FileList")}}是扁平的,这也使得知道层次结构成为可能。</p> + +<div class="note"> + <p><strong>注意:</strong>在<em>Chromium < 72</em>里,<code>webkitRelativePath</code>的行为表现有所不同。有关更多详细信息,请参见<a + href="https://bugs.chromium.org/p/chromium/issues/detail?id=124187">此bug</a>。</p> +</div> + +<h2 id="Example">示例</h2> + +<p>在这个例子中,提供了一个目录选择器,它使用户可以选择一个或多个目录。当{{event("change")}}事件被触发的时候,将生成并显示所选目录层次结构中包含的所有文件的列表。</p> + +<h3 id="HTML_content">HTML内容</h3> + +<pre class="brush: html"><input type="file" id="filepicker" name="fileList" webkitdirectory multiple /> +<ul id="listing"></ul></pre> + +<h3 id="JavaScript_content">JavaScript内容</h3> + +<pre class="brush: js">document.getElementById("filepicker").addEventListener("change", function(event) { + let output = document.getElementById("listing"); + let files = event.target.files; + + for (let i=0; i<files.length; i++) { + let item = document.createElement("li"); + item.innerHTML = files[i].webkitRelativePath; + output.appendChild(item); + }; +}, false); +</pre> + +<h3 id="Result">结果</h3> + +<p>{{ EmbedLiveSample('Example') }}</p> + +<h2 id="Specifications">规范</h2> + +<table class="standard-table"> + <thead> + <tr> + <th scope="col">Specification</th> + <th scope="col">Status</th> + <th scope="col">Comment</th> + </tr> + </thead> + <tbody> + <tr> + <td>{{ SpecName('File System API', '#dom-htmlinputelement-webkitdirectory', + 'webkitdirectory') }}</td> + <td>{{ Spec2('File System API') }}</td> + <td>Initial specification.</td> + </tr> + </tbody> +</table> + +<p>这个API没有官方的W3C或者WHATWG规范。</p> + +<h2 id="Browser_compatibility">浏览器兼容性</h2> + +<p>{{Compat("api.HTMLInputElement.webkitdirectory")}}</p> + +<h2 id="See_also">参见</h2> + +<ul> + <li><a href="/zh-CN/docs/Web/API/File_and_Directory_Entries_API">文件和目录条目API</a></li> + <li>{{domxref("HTMLInputElement.webkitEntries")}}</li> + <li>{{domxref("File.webkitRelativePath")}}</li> +</ul> |