html ondrag事件未触发,HTML ondragstart事件用法及代码示例

当可拖动元素开始拖动时,将发生HTML DOM ondragstart事件。

在拖放操作的不同阶段中使用并发生了一些事件:

在可拖动目标上触发的事件:

ondragstart:开始拖动元素时发生。

ondrag:在元素拖动时发生。

ondragend:元素拖动完成时发生。

在投放目标上触发的事件:

ondragenter:当拖动的元素进入放置目标时发生。

ondragover:当拖动的元素在放置目标上方时发生。

ondragleave:当拖动的元素从放置目标离开时发生。

ondrop:当拖动的元素放置在放置目标上时发生。

用法:

在HTML中:

在JavaScript中:

object.ondragstart = function(){myScript};

在JavaScript中,使用addEventListener()方法:

object.addEventListener("dragstart", myScript);

注意:链接和图像默认是可拖动的。

范例1:

HTML DOM ondrop Event

.droptarget {

float:center;

width:300px;

height:50px;

margin:20px;

padding:5px;

border:6px solid green;

}

GeeksforGeeks

HTML DOM ondrop Event

οndrοp="dropEle(event)"

οndragοver="allowDropEle(event)">

draggable="true"

id="dragtarget">

Dragable element

οndrοp="dropEle(event)"

οndragοver="allowDropEle(event)">

function dragStartEle(event) {

event.dataTransfer.setData(

"Text", event.target.id);

document.getElementById(

"demo").innerHTML = "Dragging starts";

}

function allowDropEle(event) {

event.preventDefault();

}

function dropEle(event) {

event.preventDefault();

var data =

event.dataTransfer.getData("Text");

event.target.appendChild(

document.getElementById(data));

document.getElementById("demo").innerHTML =

"Element dropped";

}

输出:

d6a3feda89959a48127940cf12c63e0e.gif

范例2:

HTML DOM ondrop Event

.droptarget {

float:center;

width:300px;

height:50px;

margin:20px;

padding:5px;

border:6px solid green;

}

GeeksforGeeks

HTML DOM ondrop Event

id="dragtarget">

Dragable element

// Event fired on the drag target

document.ondragstart = function(event) {

event.dataTransfer.setData("Text", event.target.id);

document.getElementById("demo").innerHTML = "Dragging starts";

};

// Events fired on the drop target

document.ondragover = function(event) {

event.preventDefault();

};

document.ondrop = function(event) {

event.preventDefault();

var data = event.dataTransfer.getData("Text");

event.target.appendChild(document.getElementById(data));

document.getElementById("demo").innerHTML = "Element dropped";

};

谷歌浏览器

IE浏览器

Firefox

苹果Safari

Opera

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值