码迷,mamicode.com
首页 > 其他好文 > 详细

拖拽的原理和封装

时间:2017-04-07 23:32:02      阅读:244      评论:0      收藏:0      [点我收藏+]

标签:事件   ne40   选中   round   就会   style   img   art   浏览器   

<body>
  <div id="div1"></div>
  <img src="1.jpg" id="img1" />
</body>
<style>
  #div1 {width: 100px; height: 100px; background: red; position: absolute;}
  #img1 { position: absolute;}
</style>
<script>
  window.onload = function() {
  /*
	1.拖拽的时候,如果有文字被选中,会产生问题
		原因:当鼠标按下的时候,如果页面中有文字被选中,那么会触发浏览器默认拖拽文字的效果
			解决:
				标准:阻止默认行为
				非标准ie:全局捕获
	拖拽图片会有问题,原因,解决的办法同上
  */
	
  /*
	ie : 有,并且有效果
	ff : 有,但是没效果
	chrome : 没有
  */
var oDiv = document.getElementById(‘div1‘); var oImg = document.getElementById(‘img1‘); drag(oImg); drag(oDiv); function drag(obj) { obj.onmousedown = function(ev) { var ev = ev || event; var disX = ev.clientX - this.offsetLeft; var disY = ev.clientY - this.offsetTop;
//设置全局捕获 ,当我们给一个元素设置全局捕获以后,那么这个元素就会监听后续发生的所有事件,当有事件发生的时候,就会被当前设置了全局捕获的元素所触发 if ( obj.setCapture ) { obj.setCapture(); } document.onmousemove = function(ev) { var ev = ev || event; obj.style.left = ev.clientX - disX + ‘px‘; obj.style.top = ev.clientY - disY + ‘px‘; } document.onmouseup = function() { document.onmousemove = document.onmouseup = null; //释放全局捕获 releaseCapture(); if ( obj.releaseCapture ) { obj.releaseCapture(); } } return false; } }
  };
</script>
 

拖拽的原理和封装

标签:事件   ne40   选中   round   就会   style   img   art   浏览器   

原文地址:http://www.cnblogs.com/chiangyibo/p/6680181.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!