html div的移动

var i=1;
function enableDrag(o)
{
if (typeof o == "string") o = document.getElementById(o);
o.orig_x = parseInt(o.style.left) - document.body.scrollLeft;
o.orig_y = parseInt(o.style.top) - document.body.scrollTop;

o.onmousedown = function(a)
{
this.style.zIndex = 100+i;
i++;
this.style.cursor = "move";
var d=document;
if(!a)a=window.event;
var x = a.clientX+d.body.scrollLeft-o.offsetLeft;
var y = a.clientY+d.body.scrollTop-o.offsetTop;

d.ondragstart = "return false;"
d.onselectstart = "return false;"
d.onselect = "document.selection.empty();"

//If the mousedown Event is in close button, close the layer and quit
if ((parseInt(o.style.width) - 30)< x && x < (parseInt(o.style.width) - 10)
&& (10 < y && y < 30))
{
setFormInvisible(o.id);
return;
}
if(o.setCapture)
o.setCapture();
else if(window.captureEvents)
window.captureEvents(Event.MOUSEMOVE|Event.MOUSEUP);

d.onmousemove = function(a)
{
if(!a)a=window.event;
o.style.left = a.clientX+document.body.scrollLeft-x;
o.style.top = a.clientY+document.body.scrollTop-y;
o.orig_x = parseInt(o.style.left) - document.body.scrollLeft;
o.orig_y = parseInt(o.style.top) - document.body.scrollTop;
}

d.onmouseup = function()
{
if(o.releaseCapture)
o.releaseCapture();
else if(window.captureEvents)
window.captureEvents(Event.MOUSEMOVE|Event.MOUSEUP);
d.onmousemove = null;
d.onmouseup = null;
d.ondragstart = null;
d.onselectstart = null;
d.onselect = null;
o.style.cursor = "normal";
}
}
}

function disableDrag(o)
{
//alert(o);
if (typeof o == "string") o = document.getElementById(o);
o.onmousedown = null;
}
// End: Functions for enabling/disabling drag and drop
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要让一个 HTML div 元素在页面中移动,可以使用 JavaScript 来实现。以下是一个简单的例子: 首先,在 HTML 页面中创建一个 div 元素,并给它一个唯一的 ID: ```html <div id="myDiv">这是一个 div 元素</div> ``` 然后,在 JavaScript 中获取这个 div 元素,并设置它的位置: ```javascript // 获取 div 元素 var myDiv = document.getElementById("myDiv"); // 设置 div 元素的位置 myDiv.style.position = "absolute"; myDiv.style.left = "100px"; myDiv.style.top = "100px"; ``` 上面的代码将 div 元素的位置设置为距离页面左边缘 100 像素,距离页面顶部 100 像素。 要让这个 div 元素在页面中移动,可以使用 JavaScript 中的 setInterval() 函数来不断更新它的位置。以下是一个例子: ```javascript // 设置 div 元素的初始位置 myDiv.style.position = "absolute"; myDiv.style.left = "100px"; myDiv.style.top = "100px"; // 设置 div 元素的移动速度 var speedX = 2; // X 轴方向的速度 var speedY = 1; // Y 轴方向的速度 // 定时器,每隔 10 毫秒更新 div 元素的位置 setInterval(function() { // 获取 div 元素的当前位置 var currentLeft = parseInt(myDiv.style.left); var currentTop = parseInt(myDiv.style.top); // 计算 div 元素的新位置 var newLeft = currentLeft + speedX; var newTop = currentTop + speedY; // 设置 div 元素的新位置 myDiv.style.left = newLeft + "px"; myDiv.style.top = newTop + "px"; // 如果 div 元素到达了页面边缘,反转速度 if (newLeft < 0 || newLeft + myDiv.offsetWidth > window.innerWidth) { speedX = -speedX; } if (newTop < 0 || newTop + myDiv.offsetHeight > window.innerHeight) { speedY = -speedY; } }, 10); ``` 上面的代码将 div 元素设置为每隔 10 毫秒更新一次位置。它会不断地改变 div 元素的 left 和 top 属性,从而让它在页面中移动。如果 div 元素到达了页面边缘,它会反转速度,从而让它回弹。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值