手机
当前位置:查字典教程网 >编程开发 >Javascript教程 >JS实现可展开折叠层的鼠标拖曳效果
JS实现可展开折叠层的鼠标拖曳效果
摘要:本文实例讲述了JS实现可展开折叠层的鼠标拖曳效果。分享给大家供大家参考。具体如下:这是一款简单JS代码实现的鼠标拖曳图层效果,比较精简,大家...

本文实例讲述了JS实现可展开折叠层的鼠标拖曳效果。分享给大家供大家参考。具体如下:

这是一款简单JS代码实现的鼠标拖曳图层效果,比较精简,大家参考一下。鼠标点击层标题栏可实现层内容的展开与折叠,按住标题栏可实现层的拖动。

运行效果截图如下:

JS实现可展开折叠层的鼠标拖曳效果1

在线演示地址如下:

http://demo.jb51.net/js/2015/js-fade-out-mouse-draw-style-demo/

具体代码如下:

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd"> <html> <head> <title>鼠标拖曳</title> </head> <body> <script type="text/javascript"> function drag(elementToDrag,event){ var startX=event.clientX,startY=event.clientY; var origX=elementToDrag.offsetLeft,origY=elementToDrag.offsetTop; var deltaX=startX-origX,deltaY=startY-origY; if(document.addEventListener){ document.addEventListener("mousemove",moveHandler,true); document.addEventListener("mouseup",upHandler,true); } else{ elementToDrag.setCapture(); elementToDrag.attachEvent("onmousemove",moveHandler); elementToDrag.attachEvent("onmouseup",upHandler); elementToDrag.attachEvent("onlosecapture",upHandler); } if(event.stopPropagation) event.stopPropagation(); else event.cancelBubble=true; if(event.preventDefault) event.preventDefault(); else event.returnValue=false; function moveHandler(e){ if(!e) e=window.event; elementToDrag.style.left=(e.clientX-deltaX)+"px"; elementToDrag.style.top=(e.clientY-deltaY)+"px"; elementToDrag.style.zIndex="10"; elementToDrag.getElementsByTagName("p")[0].innerHTML="clientX:"+e.clientX+"</br>"+"clientY:"+e.clientY+"</br>"+"offsetLeft:"+origX+"</br>"+"offsetTop:"+origY+"</br>"+"clientX-offsetLeft:"+deltaX+"</br>"+"clientY-offsetTop:"+deltaY+"</br>"; if(e.stopPropagation) e.stopPropagation(); else e.cancelBubble = true; } function upHandler(e){ if(!e) e=window.event; elementToDrag.style.zIndex="1"; if(document.removeEventListener){ document.removeEventListener("mouseup",upHandler,true); document.removeEventListener("mousemove",moveHandler,true); } else{ elementToDrag.detachEvent("onlosecapture",upHandler); elementToDrag.detachEvent("onmouseup",upHandler); elementToDrag.detachEvent("onmousemove",moveHandler); elementToDrag.releaseCapture(); } if(e.stopPropagation) e.stopPropagation(); else e.cancelBubble=true; } } </script> <div> <div onmousedown="drag(this.parentNode,event)">Drag Me1</div> <p>test</p> </div> <div> <div onmousedown="drag(this.parentNode,event)">Drag Me2</div> <p>test</p> </div> <div> <div onmousedown="drag(this.parentNode,event)">Drag Me3</div> <p>test</p> </div> </body> </html>

希望本文所述对大家的JavaScript程序设计有所帮助。

【JS实现可展开折叠层的鼠标拖曳效果】相关文章:

js实现鼠标移到链接文字弹出一个提示层的方法

jQuery实现转动随机数抽奖效果的方法

JS实现带缓冲效果打开、关闭、移动一个层的方法

JavaScript实现弹出模态窗体并接受传值的方法

JS实现窗口加载时模拟鼠标移动的方法

js实现精美的图片跟随鼠标效果实例

JQuery实现动态添加删除评论的方法

jquery实现弹出层效果实例

JS实现简单路由器功能的方法

javascript实现可全选、反选及删除表格的方法

精品推荐
分类导航