DataTransferItem: getAsFile() 方法

如果该项是文件,DataTransferItem.getAsFile() 方法将返回拖放数据项的 File 对象。如果该项不是文件,此方法将返回 null

语法

js
getAsFile()

参数

无。

返回值

File

如果拖放数据项是文件,将返回一个 File 对象;否则返回 null

示例

此示例展示了在 drop 事件处理程序中使用 getAsFile() 方法。

js
function dropHandler(ev) {
  console.log("Drop");
  ev.preventDefault();
  const data = ev.dataTransfer.items;
  for (let i = 0; i < data.length; i += 1) {
    if (data[i].kind === "string" && data[i].type.match("^text/plain")) {
      // This item is the target node
      data[i].getAsString((s) => {
        ev.target.appendChild(document.getElementById(s));
      });
    } else if (data[i].kind === "string" && data[i].type.match("^text/html")) {
      // Drag data item is HTML
      console.log("… Drop: HTML");
    } else if (
      data[i].kind === "string" &&
      data[i].type.match("^text/uri-list")
    ) {
      // Drag data item is URI
      console.log("… Drop: URI");
    } else if (data[i].kind === "file" && data[i].type.match("^image/")) {
      // Drag data item is an image file
      const f = data[i].getAsFile();
      console.log("… Drop: File");
    }
  }
}

规范

规范
HTML 标准
# dom-datatransferitem-getasfile-dev

浏览器兼容性

BCD 表格仅在浏览器中加载

另请参见