function drag(cla1,cla2,index){//鼠标可拖拽区域的dom,被拖拽的dom元素,索引var disX = 0; //鼠标到dom元素左边距离var disY = 0; //鼠标到dom元素上边距离var oDiv1 = document.getElementsByClassName(cla1)[index];var oDiv2 = document.getElementsByClassName(cla2)[index];oDiv1.onmousedown = function(ev){ var ev = ev || window.event; disX = ev.clientX - this.offsetLeft; disY = ev.clientY - this.offsetTop; document.onmousemove = function(ev){ oDiv2.style.left = ev.clientX - disX + 'px'; oDiv2.style.top = ev.clientY - disY + 'px'; if(ev.clientX - disX>=document.body.clientWidth-oDiv2.offsetWidth){ //当拖动dom超过页面右边边界 oDiv2.style.left = document.body.clientWidth-oDiv2.offsetWidth + 'px'; } if(ev.clientX - disX <= 0){ //当拖动dom超过左边边界 oDiv2.style.left = 0; } if(ev.clientY - disY>=document.body.clientHeight-oDiv2.offsetHeight){ //当拖动dom超过页面下边边界 oDiv2.style.top = document.body.clientHeight-oDiv2.offsetHeight + 'px'; } if(ev.clientY - disY <= 0){//当拖动dom超过上边边界 oDiv2.style.top = 0; } } document.onmouseup = function(ev){ //鼠标抬起移除鼠标move事件 document.onmousemove = null; } } return false;
} var divBox = document.getElementsByClassName('divBox'); for(let i = 0 ; i < divBox.length; i++ ){ drag('divHeader','divBox',i) }
转载于:https://www.cnblogs.com/wlzdf999/p/9371824.html