


Méthode JavaScript pour glisser-déposer des éléments dans des pages Web_compétences Javascript
May 16, 2016 pm 04:03 PML'exemple de cet article décrit la méthode de glisser des éléments dans une page Web à l'aide de JavaScript. Partagez-le avec tout le monde pour votre référence. Les détails sont les suivants :
Ce code décrit en détail les principes et les méthodes du glisser-déposer JS, ce qui mérite d'être appris et référencé.
/** * 跨平台的事件监听函数 * @param {Node} node 需要监听事件的DOM节点 * @param {String} eventType 需要监听的事件类型 * @param {Function} callback 事件监听回调函数 * @type Function 返回值为函数类型 * @return 返回监听回调函数的引用,用于释放监听 */ 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; } /** * 跨平台的事件监听卸载函数 * @param {Node} node 需要卸载监听事件的DOM节点 * @param {String} eventType 需要卸载监听的事件类型 * @param {Function} callback 卸载事件监听回调函数 */ 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); } } /** * 兼容不同定位方式的通用拖动接口 * @param {Node} dragger 需要被拖动的元素 */ //必须告诉系统,哪些元素是可以进行交互,而哪些是不行 function canDrag(dragger) { var drag = bindEvent(dragger,'onmousedown',function(e){ //兼容事件对象 e = e || event; //兼容坐标属性 var pageX = e.clientX || e.pageX; var pageY = e.clientY || e.pageY; //兼容样式对象 var style = dragger.currentStyle || window.getComputedStyle(dragger,null); //当没有设置left和top属性时,IE下默认值为auto var offX = parseInt(style.left) || 0; var offY = parseInt(style.top) || 0; //获取鼠标相对于元素的间距 var offXL = pageX - offX; var offYL = pageY - offY; //为dragger增加onDrag属性,用来存储拖动事件 if (!dragger.onDrag) { //监听拖动事件 dragger.onDrag = bindEvent(document,'onmousemove',function(e){ e = e || event; var x = e.clientX || e.pageX; var y = e.clientY || e.pageY //设置X坐标 dragger.style.left = x - offXL + 'px'; //设置Y坐标 dragger.style.top = y - offYL + 'px'; }); //监听拖动结束事件 dragger.onDragEnd = bindEvent(document,'onmouseup',function(e){ //释放前读取事件对象 var x = e.clientX || e.pageX; var y = e.clientY || e.pageY //释放拖动监听和结束监听 removeEvent(document, 'onmousemove', dragger.onDrag); removeEvent(document, 'onmouseup', dragger.onDragEnd); try { //删除拖动时所用的属性,兼容FF使用 delete dragger.onDrag; delete dragger.onDragEnd; } catch (e) { //删除拖动时所用的属性,兼容IE6使用 dragger.removeAttribute('onDrag'); dragger.removeAttribute('onDragEnd'); } }); } }); return function() { //返回一个可以取消拖动功能的函数引用 //释放拖动监听和结束监听 removeEvent(document, 'onmousemove', dragger.onDrag); removeEvent(document, 'onmouseup', dragger.onDragEnd); try { //删除拖动时所用的属性,兼容FF使用 delete dragger.onDrag; delete dragger.onDragEnd; } catch (e) { //删除拖动时所用的属性,兼容IE6使用 dragger.removeAttribute('onDrag'); dragger.removeAttribute('onDragEnd'); } } }
J'espère que cet article sera utile à la conception de la programmation JavaScript de chacun.

Article chaud

Outils chauds Tags

Article chaud

Tags d'article chaud

Bloc-notes++7.3.1
Éditeur de code facile à utiliser et gratuit

SublimeText3 version chinoise
Version chinoise, très simple à utiliser

Envoyer Studio 13.0.1
Puissant environnement de développement intégré PHP

Dreamweaver CS6
Outils de développement Web visuel

SublimeText3 version Mac
Logiciel d'édition de code au niveau de Dieu (SublimeText3)

Sujets chauds

Comment mettre en œuvre un système de reconnaissance vocale en ligne à l'aide de WebSocket et JavaScript

WebSocket et JavaScript : technologies clés pour mettre en œuvre des systèmes de surveillance en temps réel

Comment mettre en œuvre un système de réservation en ligne à l'aide de WebSocket et JavaScript

Explication détaillée de l'obtention par JavaScript d'éléments de page Web

Comment utiliser JavaScript et WebSocket pour mettre en œuvre un système de commande en ligne en temps réel

Tutoriel JavaScript simple : Comment obtenir le code d'état HTTP

JavaScript et WebSocket : créer un système efficace de prévisions météorologiques en temps réel

Comment utiliser insertBefore en javascript
