华夏棋牌拖放(Drag 和 drop)是 HTML5 尺度的组成部门。


华夏棋牌将w3cschool图标拖动到矩形框中。


拖放

拖放是一种有数的特点,即抓取工具以后拖到此外一个职位。

在 HTML5 中,拖放是尺度的一部门,任何元素都能够拖放。


浏览器支持

Internet Explorer

Internet Explorer 9+, Firefox, Opera, Chrome, 和 Safari 支持拖动。

重视:华夏棋牌Safari 5.1.2不支持拖动.


HTML5 拖放实例

华夏棋牌下面的例子是一个质朴的拖放实例:

实例

<!DOCTYPE HTML>
<html>
<head>
<meta charset="utf-8"> 
<title>php中文网(php.cn)</title>
<style type="text/css">
#div1 {width:350px;height:70px;padding:10px;border:1px solid #aaaaaa;}
</style>
<script>
function allowDrop(ev)
{
	ev.preventDefault();
}

function drag(ev)
{
	ev.dataTransfer.setData("Text",ev.target.id);
}

function drop(ev)
{
	ev.preventDefault();
	var data=ev.dataTransfer.getData("Text");
	ev.target.appendChild(document.getElementById(data));
}
</script>
</head>
<body>

<p>拖动 W3CSchool.cc 图片到矩形框中:</p>

<div id="div1" ondrop="drop(event)" ondragover="allowDrop(event)"></div>
<br>
<img id="drag1" src="/upload/course/000/000/010/58043146a1da1979.jpg" draggable="true" ondragstart="drag(event)" width="336" height="69">

</body>
</html>

运转实例 »

华夏棋牌点击 "运转实例" 按钮检查在线实例

它看上去或许有些严重年夜,不外我们可以划分研究拖放事宜的不合部门。


设置元素为可拖放

首先,为了使元素可拖动,把 draggable 属性设置为 true :

            <img draggable="true">


拖动甚么 - ondragstart 和 setData()

华夏棋牌然后,划定当元素被拖动时,会发生甚么。

不才面的例子中,ondragstart 属性挪用了一个函数,drag(event),它划定了被拖动的数据。

华夏棋牌dataTransfer.setData() 措施设置被拖数据的数据类型和值:

            function drag(ev)
{
ev.dataTransfer.setData("Text",ev.target.id);
}

华夏棋牌在这个例子中,数据类型是 "Text",值是可拖动元素的 id ("drag1")。


放到那里 - ondragover

ondragover 事宜划定在那里放置被拖动的数据。

华夏棋牌默许地,没法将数据/元素放置到其他元素中。假定须要设置允许放置,我们必须阻挡对元素的默许处置赏罚赏罚要领。

华夏棋牌这要经由历程挪用 ondragover 事宜的 event.preventDefault() 措施:

event.preventDefault()


阻拦放置 - ondrop

华夏棋牌当放置被拖数据时,会发生 drop 事宜。

华夏棋牌不才面的例子中,ondrop 属性挪用了一个函数,drop(event):

            function drop(ev)
{
ev.preventDefault();
var data=ev.dataTransfer.getData("Text");
ev.target.appendChild(document.getElementById(data));
}

代码诠释:

  • 华夏棋牌挪用 preventDefault() 来防止浏览器对数据的默许处置赏罚赏罚(drop 事宜的默许行动是以链接形式掀开)

  • 经由历程 dataTransfer.getData("Text") 措施取得被拖的数据。该措施将前往在 setData() 措施中设置为类似类型的任何数据。

  • 被拖数据是被拖元素的 id ("drag1")

  • 把被拖元素追加到放置元素(目的元素)中

更多实例

往复拖放图片
怎样在两个  <div>  元素之间拖放图象。

实例

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8"> 
<title>php中文网(php.cn)</title>
<style type="text/css">
#div1, #div2
{float:left; width:100px; height:35px; margin:10px;padding:10px;border:1px solid #aaaaaa;}
</style>
<script>
function allowDrop(ev)
{
	ev.preventDefault();
}

function drag(ev)
{
	ev.dataTransfer.setData("Text",ev.target.id);
}

function drop(ev)
{
	ev.preventDefault();
	var data=ev.dataTransfer.getData("Text");
	ev.target.appendChild(document.getElementById(data));
}
</script>
</head>
<body>

<div id="div1" ondrop="drop(event)" ondragover="allowDrop(event)">
	<img src="/upload/course/000/000/010/58049330dcf69494.png" draggable="true" ondragstart="drag(event)" id="drag1" width="88" height="31"></div>
<div id="div2" ondrop="drop(event)" ondragover="allowDrop(event)"></div>

</body>
</html>

运转实例 »

点击 "运转实例" 按钮检查在线实例