日期:2014-05-16 浏览次数:20524 次
<html> <head> <title>title</title> </head> <body> <div id="range" style="width:800px; height:800px; border:1px solid #333;"> fsfdsfdsf fdsfd </div><div id="bb" style="width:200px; height:200px; background-color:blue; left:0; top:0; overflow:hidden;"> <div id="ss" style="height:20px; background-color:red;"></div> <div><img src="x.png"></div> </div> <script type="text/javascript"> (function(window){ var document = window.document; var Drag = function(activeDom,dragDom){ this.mousedownHandle = this.getMousedownHandle(); this.mousemoveHandle = this.getMousemoveHandle(); this.mouseupHandle = this.getMouseupHandle(); this.bind(activeDom,dragDom); } Drag.prototype = { bind:function(activeDom,dragDom){ if(!activeDom)return; dragDom = dragDom||activeDom; dragDom.style.position = 'absolute'; activeDom.style.cursor = 'move'; this.activeDom = activeDom; this.dragDom = dragDom; return this; }, setRange:function(dom){ this.range = dom; }, start:function(){ this.listenEvent(this.activeDom,'mousedown',this.mousedownHandle); return this; }, stop:function(){ this.removeEventListen(this.activeDom,'mousedown',this.mousedownHandle); this.activeDom.style.cursor = 'default'; return this; }, getMousedownHandle:function(){ _this = this; return function(e){ e = e || window.event; _this.dx = e.clientX - _this.dragDom.offsetLeft; _this.dy = e.clientY - _this.dragDom.offsetTop; _this.listenEvent(document,'mousemove',_this.mousemoveHandle); _this.listenEvent(document,'mouseup',_this.mouseupHandle); _this.agency = _this.agency || _this.dragDom.cloneNode(false); _this.agency.style.background='none'; _this.agency.style.border = '2px solid #ccc'; _this.agency.style.left = e.clientX - _this.dx + 'px'; _this.agency.style.top = e.clientY - _this.dy + 'px'; _this.agency.style.zIndex = "999999"; document.body.appendChild(_this.agency); _this.preventDefault(e); _this.onDragBegin && _this.onDragBegin.call(_this.dragDom); } }, getMousemoveHandle:function(){ _this = this; return function(e){ e = e || window.event; _this.setPosition(e.clientX - _this.dx,e.clientY - _this.dy); _this.preventDefault(e); } }, getMouseupHandle:function(){ _this = this; return function(e){ e = e || window.event; _this.dragDom.style.left = _this.agency.offsetLeft+'px'; _this.dragDom.style.top = _this.agency.offsetTop+'px'; _this.removeEventListen(document,'mousemove',_this.mousemoveHandle); _this.removeEventListen(document,'mouseup',_this.mouseupHandle); document.body.removeChild(_this.agency); _this.onDragEnd && _this.onDragEnd.call(_this.dragDom); } }, setPosition:function(x,y){ var range; if(range = _this.range){ if(x<range.offsetLeft)x=range.offsetLeft; if(y<