<!DOCTYPE html>
<html lang="en">
<head>
	<meta charset="UTF-8">
	<title>拖拽</title>
	<style>
		*{ margin: 0; padding: 0; }
		#div1{ width: 100px; height: 100px; background-color: #669; position: absolute; left: 20px; top: 20px; cursor: move; }
		#div2{ width: 100px; height: 100px; background-color: #996; position: absolute; left: 200px; top: 200px; cursor: move; }
	</style>
</head>
<body>
	<div id="div1">拖动的时候不会选中我</div>
	<div id="div2">拖动的时候不会选中我</div>
	<script>
		var page = {
			oEvent: function(ev){
				return ev || event;
			},
			pageX: function(ev){
				var e = this.oEvent(ev);
				return e.clientX;
			},
			pageY: function(ev){
				var e = this.oEvent(ev);
				return e.clientY;
			},
			disX: function(ev){
				var e = this.oEvent(ev);
				return e.layerX || e.offsetX;
			},
			disY: function(ev){
				var e = this.oEvent(ev);
				return e.layerY || e.offsetY;
			}
		}
		drap("div1", page);
		drap("div2", page);
		function drap(id,option){
			var $$ = function(id){
				return document.getElementById(id);
			}
			$$(id).onmousedown = function(ev){
				var disX = option.disX();
				var disY = option.disY();
				document.onmousemove = function(ev){
					var left = option.pageX() - disX;
					var top  = option.pageY() - disY;
					$$(id).style.left = left + "px";
					$$(id).style.top =  top + "px";
				}
				document.onmouseup = function(){
					document.onmousemove = null;
					document.onmouseup = null;
				}
				return false;
			}
		}
	</script>
</body>
</html>
原文:http://www.cnblogs.com/wzh1995/p/6782379.html