DataTransferItem.kind

DataTransferItem.kind プロパティは読み取り専用で、 ドラッグデータ項目 の種類(テキストまたはファイル)を表す DataTransferItem を返すものです。

ドラッグデータ項目の種類を表す文字列です。以下の値のいずれかでなければなりません。

'file'

ドラッグデータ項目がファイルの場合。

'string'

ドラッグデータ項目の種類が プレーン Unicode 文字列 である場合。

この例では、 kind プロパティを使用しています。

js
function drop_handler(ev) {
  console.log("Drop");
  ev.preventDefault();
  const data = event.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 === "file" && data[i].type.match("^image/")) {
      // Drag data item is an image file
      const f = data[i].getAsFile();
      console.log("… Drop: File ");
    }
  }
}

仕様書

Specification
HTML Standard
# dom-datatransferitem-kind-dev

ブラウザーの互換性

BCD tables only load in the browser

関連情報