|
热门文章 |
|
|
|
|
文字、图片拖曳移动 |
来源:源码爱好者 更新时间:2010/8/14 0:48:50 阅读次数: 我要投稿 |
|
<html> <head> <title>文字与图片被拖曳</title> <style type="text/css"> *{padding:0;margin:0;} .tips{position:absolute;background:#eee;} </style> </head> <body> <div class="tips" id="tips1" onmouseover="dragF.drag('tips1');"> <img src="/effects/UploadFiles_7074/201008/2010081400505349.gif">拖动图片</div> <div class="tips" id="tips2" onmouseover="dragF.drag('tips2');"><a href="http://www.cwydesign.com" target="_blank">链接</a><br /> 拖动链接也可以 </div> </body> <script type="text/javascript"> var $id=function(id){return document.getElementById(id);} var dragF={ locked:false, lastObj:undefined, drag:function(obj){ $id(obj).onmousedown=function(e){ var e = e ? e : window.event; if(!window.event) {e.preventDefault();}/* 阻止标注浏览器下拖动a,img的默认事件 */ dragF.locked=true; $id(obj).style.position="absolute"; $id(obj).style.zIndex="100"; if (dragF.lastObj&&dragF.lastObj!=$id(obj)) {/* 多元素拖动时候需要恢复上一次元素的状态 */ dragF.lastObj.style.zIndex = "1"; } dragF.lastObj=$id(obj); var tempX=$id(obj).offsetLeft; var tempY=$id(obj).offsetTop; dragF.x=e.clientX; dragF.y=e.clientY; document.onmousemove=function(e){ var e = e ? e : window.event; if(dragF.locked==false) return false; $id(obj).style.left=tempX+e.clientX-dragF.x+"px"; $id(obj).style.top=tempY+e.clientY-dragF.y+"px"; if(window.event) {e.returnValue=false;}/* 阻止ie下a,img的默认事件 */ } document.onmouseup=function(){ dragF.locked=false; } } } } </script> </html> |
特效说明: |
文字与图片的拖动效果,也可以拖动链接,操作体验挺不错,JavaScript代码实现,无jQeury,而且代码实现很简化,效果不错。 |
|
上一篇文章: JavaScript 动为表格的每一行增加序号下一篇文章: 点击展开的文章评论效果 |
|
|