六狼论坛

 找回密码
 立即注册

QQ登录

只需一步,快速开始

新浪微博账号登陆

只需一步,快速开始

搜索
查看: 90|回复: 0

js div move

[复制链接]

升级  15.33%

19

主题

19

主题

19

主题

秀才

Rank: 2

积分
73
 楼主| 发表于 2013-2-7 20:18:19 | 显示全部楼层 |阅读模式
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head><meta http-equiv="Content-Type" content="text/html; charset=gb2312" /><title>div move</title></head><body><div id="movID"style="border:1px dashed blue; width: 500px; height: 500px; left:50px; top:50px; position :absolute; zIndex: 2001; background-color: #FFFFFF;"></div></body><script type="text/javascript">window.onload = function(){var div = document.getElementById("movID");div.onmousedown = function(event){fDragging(div, event, false);}}function fDragging(obj, e, limit) {    if (!e) e = window.event;    var x = parseInt(obj.style.left);    var y = parseInt(obj.style.top);    var x_ = e.clientX - x;    var y_ = e.clientY - y;    if (document.addEventListener) {        document.addEventListener('mousemove', inFmove, true);        document.addEventListener('mouseup', inFup, true);    } else if (document.attachEvent) {        document.attachEvent('onmousemove', inFmove);        document.attachEvent('onmouseup', inFup);    }    inFstop(e);    inFabort(e);    function inFmove(e) {        var evt;        if (!e) e = window.event;        if (limit) {            var op = obj.parentNode;            var opX = parseInt(op.style.left);            var opY = parseInt(op.style.top);            if ((e.clientX - x_) < 0) return false;            else if ((e.clientX - x_ + obj.offsetWidth + opX) > (opX + op.offsetWidth)) return false;            if (e.clientY - y_ < 0) return false;            else if ((e.clientY - y_ + obj.offsetHeight + opY) > (opY + op.offsetHeight)) return false;        }        obj.style.left = e.clientX - x_ + 'px';        obj.style.top = e.clientY - y_ + 'px';        inFstop(e);    }    function inFup(e) {        var evt;        if (!e) e = window.event;        if (document.removeEventListener) {            document.removeEventListener('mousemove', inFmove, true);            document.removeEventListener('mouseup', inFup, true);        } else if (document.detachEvent) {            document.detachEvent('onmousemove', inFmove);            document.detachEvent('onmouseup', inFup);        }        inFstop(e);    }    function inFstop(e) {        if (e.stopPropagation) return e.stopPropagation();        else return e.cancelBubble = true;    }    function inFabort(e) {        if (e.preventDefault) return e.preventDefault();        else return e.returnValue = false;    }}</script></html>
您需要登录后才可以回帖 登录 | 立即注册 新浪微博账号登陆

本版积分规则

快速回复 返回顶部 返回列表