DataTransfer: effectAllowed 属性

Baseline 已广泛支持

此特性已相当成熟,可在许多设备和浏览器版本上使用。自 ⁨2015 年 7 月⁩以来,各浏览器均已提供此特性。

DataTransfer.effectAllowed 属性指定允许的拖放操作的效果。copy 操作用于指示正在拖动的数据将从其当前位置复制到放置位置。move 操作用于指示正在拖动的数据将被移动,而 link 操作用于指示将在源位置和放置位置之间创建某种形式的关系或连接。

此属性应在 dragstart 事件中设置,以设置拖动源所需的拖动效果。在 dragenterdragover 事件处理程序中,此属性将被设置为在 dragstart 事件期间分配的任何值,因此 effectAllowed 可用于确定允许哪种效果。

dragstart 事件以外的其他事件中为 effectAllowed 赋值没有效果。

一个表示允许的拖放操作的字符串。可能的值有:

none

无法放置该项。

copy

可以在新位置创建源项的副本。

允许复制或链接操作。

copyMove

允许复制或移动操作。

可以建立指向新位置源的链接。

linkMove

允许链接或移动操作。

move

可以将一项移动到新位置。

all

允许所有操作。

uninitialized

当效果未设置时的默认值,等同于 all。

effectAllowed 赋值任何其他值都没有效果,并且会保留旧值。

示例

设置 effectAllowed

在此示例中,我们在 dragstart 处理程序中将 effectAllowed 设置为 "move"

HTML

html
<div>
  <p id="source" draggable="true">
    Select this element, drag it to the Drop Zone and then release the selection
    to move the element.
  </p>
</div>
<div id="target">Drop Zone</div>
<pre id="output"></pre>
<button id="reset">Reset</button>

CSS

css
div {
  margin: 0em;
  padding: 2em;
}

#source {
  color: blue;
  border: 1px solid black;
}

#target {
  border: 1px solid black;
}

#output {
  height: 100px;
  overflow: scroll;
}

JavaScript

js
function dragstartHandler(ev) {
  log(`dragstart: effectAllowed = ${ev.dataTransfer.effectAllowed}`);

  // Add this element's id to the drag payload so the drop handler will
  // know which element to add to its tree
  ev.dataTransfer.setData("text", ev.target.id);
  ev.dataTransfer.effectAllowed = "move";
}

function dropHandler(ev) {
  log(`drop: effectAllowed = ${ev.dataTransfer.effectAllowed}`);

  ev.preventDefault();
  // Get the id of the target and add the element to the target's DOM
  const data = ev.dataTransfer.getData("text");
  ev.target.appendChild(document.getElementById(data));
}

function dragoverHandler(ev) {
  log(`dragover: effectAllowed = ${ev.dataTransfer.effectAllowed}`);
  ev.preventDefault();
}

const source = document.querySelector("#source");
const target = document.querySelector("#target");

source.addEventListener("dragstart", dragstartHandler);
target.addEventListener("dragover", dragoverHandler);
target.addEventListener("drop", dropHandler);

function log(message) {
  const output = document.querySelector("#output");
  output.textContent = `${output.textContent}\n${message}`;
  output.scrollTop = output.scrollHeight;
}

const reset = document.querySelector("#reset");
reset.addEventListener("click", () => document.location.reload());

结果

规范

规范
HTML
# dom-datatransfer-effectallowed-dev

浏览器兼容性

另见