91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

HTML5中如何實現拖放效果無須借助javascript

發布時間:2022-02-28 14:57:38 來源:億速云 閱讀:123 作者:小新 欄目:web開發

這篇文章給大家分享的是有關HTML5中如何實現拖放效果無須借助javascript的內容。小編覺得挺實用的,因此分享給大家做個參考,一起跟隨小編過來看看吧。

先看html核心代碼:

<div>

<p>把黃色小方塊拖入到紅色大方框中</p>

</div>

<div id="item" draggable="true">

</div>

<div id="drop">

</div>

draggable屬性是HTML5/">html5新增加的,它有三個值true,false,auto. true是可以拖,false是不可以,auto由用戶瀏覽器是否支持而定。

加上一點兒樣式:

<style type="text/css">

#drop

{

width: 300px;

height: 200px;

background-color: #ff0000;

padding: 5px;

border: 2px solid #000000;

}

#item

{

width: 100px;

height: 100px;

background-color: #ffff00;

padding: 5px;

margin: 20px;

border: 1px dashed #000000;

}

*[draggable=true] {

-moz-user-select:none;

-khtml-user-drag: element;

cursor: move;

}

*:-khtml-drag {

background-color: rgba(238,238,238, 0.5);

}

</style>

然后我們來看javascript:

function listenEvent(eventTarget, eventType, eventHandler) {

if (eventTarget.addEventListener) {

eventTarget.addEventListener(eventType, eventHandler,false);

} else if (eventTarget.attachEvent) {

eventType = "on" + eventType;

eventTarget.attachEvent(eventType, eventHandler);

} else {

eventTarget["on" + eventType] = eventHandler;

}

}

// cancel event

function cancelEvent (event) {

if (event.preventDefault) {

event.preventDefault();

} else {

event.returnValue = false;

}

}

// cancel propagation

function cancelPropagation (event) {

if (event.stopPropagation) {

event.stopPropagation();

} else {

event.cancelBubble = true;

}

}

window.onload=function() {

var target = document.getElementById("drop");

listenEvent(target,"dragenter",cancelEvent);

listenEvent(target,"dragover", dragOver);

listenEvent(target,"drop",function (evt) {

cancelPropagation(evt);

evt = evt || window.event;

evt.dataTransfer.dropEffect = 'copy';

var id = evt.dataTransfer.getData("Text");

target.appendChild(document.getElementById(id));

});

var item = document.getElementById("item");

item.setAttribute("draggable", "true");

listenEvent(item,"dragstart", function(evt) {

evt = evt || window.event;

evt.dataTransfer.effectAllowed = 'copy';

evt.dataTransfer.setData("Text",item.id);

});

};

function dragOver(evt) {

if (evt.preventDefault) evt.preventDefault();

evt = evt || window.event;

evt.dataTransfer.dropEffect = 'copy';

return false;

}

由上面的代碼我們看使用一組HTML5 提供的拖放Events,直接來看下面:

dragstart

Drag event starts.

drag

During the drag operation.

dragenter

Drag is over the target; used to determine if target will accept drop.

dragover

Drag is over target; used to determine feedback to user.

drop

Drop occurs.

dragleave

Drag leaves target.

dragend

Drag operation ends.

定義了相關的事件,來實現想要功能。上面的Js不難看懂。

你可以自己試一下,目前在Opera支持最好,IE效果并不好。

感謝各位的閱讀!關于“HTML5中如何實現拖放效果無須借助javascript”這篇文章就分享到這里了,希望以上內容可以對大家有一定的幫助,讓大家可以學到更多知識,如果覺得文章不錯,可以把它分享出去讓更多的人看到吧!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

定安县| 建湖县| 崇文区| 会东县| 云南省| 宁乡县| 沙洋县| 夏邑县| 垣曲县| 纳雍县| 炎陵县| 龙江县| 格尔木市| 荔波县| 新蔡县| 西吉县| 蕉岭县| 吉木萨尔县| 静安区| 达孜县| 兴安盟| 蚌埠市| 商丘市| 安宁市| 子洲县| 绥德县| 安西县| 白河县| 凤山市| 吴旗县| 云南省| 成都市| 万年县| 柘城县| 泗洪县| 临西县| 广西| 巴青县| 望城县| 铁力市| 喀什市|