使用dreamweaver看别人的代码时,发现,在一个父级div下的子级div可以在设计窗口自由拖动位置,怎么做的?
展开全部
<html>
<head>
<title>DragDiv</title>
<script language="javascript">
/* 《可拖动的div》思路:
1.拖动div的position须为absolute,因为它不遵循html默认的flow
2.拖动事件包括(点住鼠标-->移动鼠标-->释放鼠标)
3.拖动div的位移量就是点住鼠标时的鼠标坐标(x,y)-释放鼠标时的鼠标坐标(x,y)。所以需要监听onmousedown和onmouseup事件。
======
*全局变量:
*oldMouseX:鼠标在事件触发时的X坐标,初始化为0
*oldMouseY:鼠标在事件触发时的Y坐标,初始化为0
*dragObjStatus:是否执行拖拽动作的flag,初始化为0,0-不执行,1-执行
*dragObj:拖拽的对象元素,初始化为null
*/
// 初始化拖拽的全局变量
var oldMouseX = 0;
var oldMouseY = 0;
var dragObjStatus = 0;
var dragObj = null;
function startDrag(e) {
var eve = window.event || e;
//得到触发事件的源对象,也就是要拖拽的对象
if(!eve.target) {
eve.target = eve.srcElement;
}
//如果事件的源对象不是body,初始化全局变量,为拖拽做好准备,否则就还原全局变量为默认值
if(eve.target.tagName.toLowerCase() != 'body') {
oldMouseX = eve.clientX;
oldMouseY = eve.clientY;
dragObjStatus = 1;
dragObj = eve.target;
} else {
oldMouseX = 0;
oldMouseY = 0;
dragObjStatus = 0;
dragObj = null;
}
}
/**
*完成拖拽
*/
function overDrag(e) {
var eve = window.event || e;
if(dragObjStatus == 1) {
var newMouseX = eve.clientX , newMouseY = eve.clientY;
if(dragObj) {
//拖拽对象的初始X、Y坐标
var objX = parseInt(dragObj.style.left) , objY = parseInt(dragObj.style.top);
//拖拽对象拖拽后的X,Y坐标
dragObj.style.left = (objX + (newMouseX - oldMouseX)) + "px";
dragObj.style.top = (objY + (newMouseY - oldMouseY)) + "px";
}
//还原全局变量为默认值
oldMouseX = 0;
oldMouseY = 0;
dragObjStatus = 0;
dragObj = null;
}
}
window.onload = function() { //随时监测鼠标事件
window.document.onmousedown = function(e){ startDrag(e);};
window.document.onmouseup = function(e) { overDrag(e);};
};
</script>
</head>
<body>
<div id="dragobj1" style="width:20%;height:60px;background-color:green;position:absolute;left:30px;top:40px;cursor:hand;">拖放div1</div>
<div id="dragobj2" style="width:20%;height:60px;background-color:red;position:absolute;left:70px;top:90px;cursor:hand;"> dragobj2 </div>
</body>
</html>
<head>
<title>DragDiv</title>
<script language="javascript">
/* 《可拖动的div》思路:
1.拖动div的position须为absolute,因为它不遵循html默认的flow
2.拖动事件包括(点住鼠标-->移动鼠标-->释放鼠标)
3.拖动div的位移量就是点住鼠标时的鼠标坐标(x,y)-释放鼠标时的鼠标坐标(x,y)。所以需要监听onmousedown和onmouseup事件。
======
*全局变量:
*oldMouseX:鼠标在事件触发时的X坐标,初始化为0
*oldMouseY:鼠标在事件触发时的Y坐标,初始化为0
*dragObjStatus:是否执行拖拽动作的flag,初始化为0,0-不执行,1-执行
*dragObj:拖拽的对象元素,初始化为null
*/
// 初始化拖拽的全局变量
var oldMouseX = 0;
var oldMouseY = 0;
var dragObjStatus = 0;
var dragObj = null;
function startDrag(e) {
var eve = window.event || e;
//得到触发事件的源对象,也就是要拖拽的对象
if(!eve.target) {
eve.target = eve.srcElement;
}
//如果事件的源对象不是body,初始化全局变量,为拖拽做好准备,否则就还原全局变量为默认值
if(eve.target.tagName.toLowerCase() != 'body') {
oldMouseX = eve.clientX;
oldMouseY = eve.clientY;
dragObjStatus = 1;
dragObj = eve.target;
} else {
oldMouseX = 0;
oldMouseY = 0;
dragObjStatus = 0;
dragObj = null;
}
}
/**
*完成拖拽
*/
function overDrag(e) {
var eve = window.event || e;
if(dragObjStatus == 1) {
var newMouseX = eve.clientX , newMouseY = eve.clientY;
if(dragObj) {
//拖拽对象的初始X、Y坐标
var objX = parseInt(dragObj.style.left) , objY = parseInt(dragObj.style.top);
//拖拽对象拖拽后的X,Y坐标
dragObj.style.left = (objX + (newMouseX - oldMouseX)) + "px";
dragObj.style.top = (objY + (newMouseY - oldMouseY)) + "px";
}
//还原全局变量为默认值
oldMouseX = 0;
oldMouseY = 0;
dragObjStatus = 0;
dragObj = null;
}
}
window.onload = function() { //随时监测鼠标事件
window.document.onmousedown = function(e){ startDrag(e);};
window.document.onmouseup = function(e) { overDrag(e);};
};
</script>
</head>
<body>
<div id="dragobj1" style="width:20%;height:60px;background-color:green;position:absolute;left:30px;top:40px;cursor:hand;">拖放div1</div>
<div id="dragobj2" style="width:20%;height:60px;background-color:red;position:absolute;left:70px;top:90px;cursor:hand;"> dragobj2 </div>
</body>
</html>
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询