DataTransferItem.kind

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

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

'file'

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

'string'

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

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

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

関連情報