茄子在线看片免费人成视频,午夜福利精品a在线观看,国产高清自产拍在线观看,久久综合久久狠狠综合

    <s id="ddbnn"></s>
  • <sub id="ddbnn"><ol id="ddbnn"></ol></sub>

  • <legend id="ddbnn"></legend><s id="ddbnn"></s>

    JavaScript實(shí)現(xiàn)拖拽網(wǎng)頁(yè)內(nèi)元素的方法
    來(lái)源:易賢網(wǎng) 閱讀:982 次 日期: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)聽(tīng)函數(shù)

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

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

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

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

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

    */

    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)聽(tīng)卸載函數(shù)

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

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

    * @param {Function} callback 卸載事件監(jiān)聽(tīng)回調(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)聽(tīng)拖動(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)聽(tīng)拖動(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)聽(tīng)和結(jié)束監(jiān)聽(tīng)

    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)聽(tīng)和結(jié)束監(jiān)聽(tīng)

    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)!

    2026國(guó)考·省考課程試聽(tīng)報(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)