DataTransferItem.webkitGetAsEntry() - Web API 接口参考 编辑
如果由文件描述的项目DataTransferItem
是文件,则webkitGetAsEntry()
返回FileSystemFileEntry
或FileSystemDirectoryEntry
表示它。如果该项不是文件,null
则返回。
此功能webkitGetAsEntry()
在此时非包含Firefox的非WebKit浏览器中实现; 它可能会getAsEntry()
在以后简单地重命名,所以你应该进行防御性编码,寻找两者。
语法
DataTransferItem.webkitGetAsEntry();
参数
没有。
返回值
FileSystemEntry
基于A 的对象描述被删除的项目。这将是FileSystemFileEntry
或FileSystemDirectoryEntry
。
示例
在此示例中,创建了一个放置区域,该放置区域drop
通过扫描已删除的文件和目录来响应事件,从而输出分层目录列表。
HTML内容
HTML建立了放置区本身,它是<div>
具有ID 的元素"dropzone"
,以及带有ID 的无序列表元素"listing"
。
<p>Drag files and/or directories to the box below!</p>
<div id="dropzone">
<div id="boxtitle">
Drop Files Here
</div>
</div>
<h2>Directory tree:</h2>
<ul id="listing">
</ul>
CSS内容
此处显示示例使用的样式。
#dropzone {
text-align: center;
width: 300px;
height: 100px;
margin: 10px;
padding: 10px;
border: 4px dashed red;
border-radius: 10px;
}
#boxtitle {
display: table-cell;
vertical-align: middle;
text-align: center;
color: black;
font: bold 2em "Arial", sans-serif;
width: 300px;
height: 100px;
}
body {
font: 14px "Arial", sans-serif;
}
JavaScript内容
首先,让我们看一下递归scanFiles()
函数。该函数将FileSystemEntry
表示要扫描和处理的文件系统中的条目(item
参数)和插入内容列表(container
参数)的元素作为输入。
请注意,要读取目录中的所有文件,readEntries
需要重复调用,直到它返回一个空数组。在基于Chromium的浏览器中,以下示例仅返回最多100个条目。
let dropzone = document.getElementById("dropzone");
let listing = document.getElementById("listing");
function scanFiles(item, container) {
let elem = document.createElement("li");
elem.innerHTML = item.name;
container.appendChild(elem);
if (item.isDirectory) {
let directoryReader = item.createReader();
let directoryContainer = document.createElement("ul");
container.appendChild(directoryContainer);
directoryReader.readEntries(function(entries) {
entries.forEach(function(entry) {
scanFiles(entry, directoryContainer);
});
});
}
}
scanFiles()
首先创建一个新<li>
元素来表示正在扫描的项目,将项目的名称作为文本内容插入其中,然后将其附加到容器中。容器在此示例中始终是列表元素,您很快就会看到。
一旦当前项目在列表中,isDirectory
就会检查项目的属性。如果该项目是目录,我们需要递归到该目录。第一步是创建一个FileSystemDirectoryReader
to来处理获取目录的内容。这是通过调用item的createReader()
方法完成的。然后<ul>
创建一个new 并将其附加到父列表; 这将包含列表层次结构中下一级别的目录内容。
之后,directoryReader.readEntries()
调用读取目录中的所有条目。反过来,这些都被传递到递归调用scanFiles()
以处理它们。其中任何文件都只是插入到列表中; 将任何目录插入到列表中,并在下面添加列表层次结构的新级别,依此类推。
然后是事件处理程序。首先,我们阻止dragover
事件由默认处理程序处理,以便我们的drop区域可以接收drop:
dropzone.addEventListener("dragover", function(event) {
event.preventDefault();
}, false);
当然,关闭所有事件的事件处理程序是事件的处理程序drop
:
dropzone.addEventListener("drop", function(event) {
let items = event.dataTransfer.items;
event.preventDefault();
listing.innerHTML = "";
for (let i=0; i<items.length; i++) {
let item = items[i].webkitGetAsEntry();
if (item) {
scanFiles(item, listing);
}
}
}, false);
这将获取DataTransferItem
表示从中删除的项目的对象列表event.dataTransfer.items
。然后我们打电话Event.preventDefault()
来防止事件在完成后被进一步处理。
现在是时候开始构建列表了。首先,通过设置listing.innerHTML
为空来清空列表。这使我们ul
开始插入目录条目为空。
然后我们遍历已删除项目列表中的项目。对于每一个,我们调用它的webkitGetAsEntry()
方法来获得FileSystemEntry
表示文件。如果成功,我们会调用scanFiles()
处理项目 - 如果它只是一个文件,或者添加它,如果它是一个目录,则将其添加到列表中。
结果
你可以通过下面的尝试看看它是如何工作的。 找到一些文件和目录并将其拖入,然后查看生成的输出。
Specifications
Specification | Status | Comment |
---|---|---|
File and Directory Entries API webkitGetAsEntry() | Draft | 初始规格。 |
此API没有官方的W3C或WHATWG规范。
浏览器兼容性
BCD tables only load in the browser
此页面上的兼容性表是根据结构化数据生成的。如果您想为数据做出贡献,请查看https://github.com/mdn/browser-compat-data并向我们发送拉取请求。也可以看看
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
发布评论