JavaScript實(shí)現(xiàn)拖拽網(wǎng)頁(yè)內(nèi)元素的方法
來(lái)源:易賢網(wǎng) 閱讀:792 次 日期:2015-04-20 14:06:49
溫馨提示:易賢網(wǎng)小編為您整理了“JavaScript實(shí)現(xiàn)拖拽網(wǎng)頁(yè)內(nèi)元素的方法”,方便廣大網(wǎng)友查閱!

這段代碼詳細(xì)講述了JS拖拽的原理和方法,值得學(xué)習(xí)和借鑒。

/**

* 跨平臺(tái)的事件監(jiān)聽函數(shù)

* @param {Node} node 需要監(jiān)聽事件的DOM節(jié)點(diǎn)

* @param {String} eventType 需要監(jiān)聽的事件類型

* @param {Function} callback 事件監(jiān)聽回調(diào)函數(shù)

* @type Function 返回值為函數(shù)類型

* @return 返回監(jiān)聽回調(diào)函數(shù)的引用,用于釋放監(jiān)聽

*/

function bindEvent(node, eventType, callback) {

if (node.attachEvent) {

if (eventType.indexOf('on')) { eventType = 'on' + eventType;}

node.attachEvent(eventType, callback);

} else {

if (!eventType.indexOf('on'))

eventType = eventType.substring(2, eventType.length);

node.addEventListener(eventType, callback, false);

}

return callback;

}

/**

* 跨平臺(tái)的事件監(jiān)聽卸載函數(shù)

* @param {Node} node 需要卸載監(jiān)聽事件的DOM節(jié)點(diǎn)

* @param {String} eventType 需要卸載監(jiān)聽的事件類型

* @param {Function} callback 卸載事件監(jiān)聽回調(diào)函數(shù)

*/

function removeEvent(node, eventType, callback) {

if (node.detachEvent) {

if (eventType.indexOf('on')) { eventType = 'on' + eventType;}

node.detachEvent(eventType, callback);

} else {

if (!eventType.indexOf('on'))

eventType = eventType.substring(2, eventType.length);

node.removeEventListener(eventType, callback, false);

}

}

/**

* 兼容不同定位方式的通用拖動(dòng)接口

* @param {Node} dragger 需要被拖動(dòng)的元素

*/

//必須告訴系統(tǒng),哪些元素是可以進(jìn)行交互,而哪些是不行

function canDrag(dragger) {

var drag = bindEvent(dragger,'onmousedown',function(e){

//兼容事件對(duì)象

e = e || event;

//兼容坐標(biāo)屬性

var pageX = e.clientX || e.pageX;

var pageY = e.clientY || e.pageY;

//兼容樣式對(duì)象

var style = dragger.currentStyle || window.getComputedStyle(dragger,null);

//當(dāng)沒(méi)有設(shè)置left和top屬性時(shí),IE下默認(rèn)值為auto

var offX = parseInt(style.left) || 0;

var offY = parseInt(style.top) || 0;

//獲取鼠標(biāo)相對(duì)于元素的間距

var offXL = pageX - offX;

var offYL = pageY - offY;

//為dragger增加onDrag屬性,用來(lái)存儲(chǔ)拖動(dòng)事件

if (!dragger.onDrag) {

//監(jiān)聽拖動(dòng)事件

dragger.onDrag = bindEvent(document,'onmousemove',function(e){

e = e || event;

var x = e.clientX || e.pageX;

var y = e.clientY || e.pageY

//設(shè)置X坐標(biāo)

dragger.style.left = x - offXL + 'px';

//設(shè)置Y坐標(biāo)

dragger.style.top = y - offYL + 'px';

});

//監(jiān)聽拖動(dòng)結(jié)束事件

dragger.onDragEnd = bindEvent(document,'onmouseup',function(e){

//釋放前讀取事件對(duì)象

var x = e.clientX || e.pageX;

var y = e.clientY || e.pageY

//釋放拖動(dòng)監(jiān)聽和結(jié)束監(jiān)聽

removeEvent(document, 'onmousemove', dragger.onDrag);

removeEvent(document, 'onmouseup', dragger.onDragEnd);

try {

//刪除拖動(dòng)時(shí)所用的屬性,兼容FF使用

delete dragger.onDrag;

delete dragger.onDragEnd;

} catch (e) {

//刪除拖動(dòng)時(shí)所用的屬性,兼容IE6使用

dragger.removeAttribute('onDrag');

dragger.removeAttribute('onDragEnd');

}

});

}

});

return function() {

//返回一個(gè)可以取消拖動(dòng)功能的函數(shù)引用

//釋放拖動(dòng)監(jiān)聽和結(jié)束監(jiān)聽

removeEvent(document, 'onmousemove', dragger.onDrag);

removeEvent(document, 'onmouseup', dragger.onDragEnd);

try {

//刪除拖動(dòng)時(shí)所用的屬性,兼容FF使用

delete dragger.onDrag;

delete dragger.onDragEnd;

} catch (e) {

//刪除拖動(dòng)時(shí)所用的屬性,兼容IE6使用

dragger.removeAttribute('onDrag');

dragger.removeAttribute('onDragEnd');

}

}

}

更多信息請(qǐng)查看IT技術(shù)專欄

更多信息請(qǐng)查看腳本欄目
由于各方面情況的不斷調(diào)整與變化,易賢網(wǎng)提供的所有考試信息和咨詢回復(fù)僅供參考,敬請(qǐng)考生以權(quán)威部門公布的正式信息和咨詢?yōu)闇?zhǔn)!

2025國(guó)考·省考課程試聽報(bào)名

  • 報(bào)班類型
  • 姓名
  • 手機(jī)號(hào)
  • 驗(yàn)證碼
關(guān)于我們 | 聯(lián)系我們 | 人才招聘 | 網(wǎng)站聲明 | 網(wǎng)站幫助 | 非正式的簡(jiǎn)要咨詢 | 簡(jiǎn)要咨詢須知 | 新媒體/短視頻平臺(tái) | 手機(jī)站點(diǎn) | 投訴建議
工業(yè)和信息化部備案號(hào):滇ICP備2023014141號(hào)-1 云南省教育廳備案號(hào):云教ICP備0901021 滇公網(wǎng)安備53010202001879號(hào) 人力資源服務(wù)許可證:(云)人服證字(2023)第0102001523號(hào)
云南網(wǎng)警備案專用圖標(biāo)
聯(lián)系電話:0871-65099533/13759567129 獲取招聘考試信息及咨詢關(guān)注公眾號(hào):hfpxwx
咨詢QQ:1093837350(9:00—18:00)版權(quán)所有:易賢網(wǎng)
云南網(wǎng)警報(bào)警專用圖標(biāo)