爱易网
IT新闻
IT新闻
爱易资讯
网站搭建
云虚拟主机教程
云服务器教程
Apache教程
IIS教程
Nginx教程
网站策划
站长文章
推广教程
淘宝客教程
网页设计
HTML教程
XHTML教程
CSS教程
HTML5教程
CSS3教程
JavaSript基础
JQuery教程
Node.js教程
前端技术
Ajax教程
Js特效
Xml教程
平面设计
页面UI设计
photoshop教程
程序开发
AI人工智能
Asp教程
Php教程
Asp.Net教程
Net Core教程
C#教程
Java教程
Jsp教程
开发技术
微信小程序教程
Uniapp开发教程
微信公众号开发
Andriod教程
IOS教程
DOS教程
Python教程
Docker教程
Windows Container教程
数据库
MSSQL教程
MySQL教程
Redis教程
Access教程
Oracle教程
数据库教程
操作系统
Linux教程
Windows教程
MAC教程
Cisco教程
交换机教程
防火墙教程
搜索
爱易网页
JS特效
js制作一个在特定范围内可拖动的层
js制作一个在特定范围内可拖动的层
日期:2014-05-18 浏览次数:20342 次
以下是程序代码
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/strict.dtd"> <html> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8"> <title>范围内拖动效果</title> <style> /* 绝对定位 */ #dragger1{ width:100px; height:100px; background:#bbb; position:absolute; left:0px; top:0px; cursor:move; } .border{ border:1px solid #ccc; width:600px; height:600px; position:relative; margin:100px auto; } </style> </head> <body unselectable="on" onselectstart="return false;" style="-moz-user-select:none;"> <div class="border" id="bor"> <div id='dragger1'>可以在范围内拖动</div> </div> <script> var _$ = function(id){ return document.getElementById(id); } function bindEvent(node,eventType,callback){ if(node.attachEvent){ if(eventType.indexOf('on')){eventType = 'on' + eventType} node.attachEvent(eventType,callback); } else{ if(!eventType.indexOf('on')){ eventType = eventType.substring(2,eventType.length) } node.addEventListener(eventType,callback,false); } return callback; } function removeEvent(node,eventType,callback){ if(node.detachEvent){ if(eventType.indexOf('on')){eventType = 'on' + eventType} node.detachEvent(eventType,callback); } else{ if(!eventType.indexOf('on')){ eventType = eventType.substring(2,eventType.length); } node.removeEventListener(eventType,callback,false); } } //创建接口 function __drag__(dragger){ var drag = bindEvent(dragger,'onmousedown',function(e){ e = e || event; var mouseX = e.clientX || e.pageX; var mouseY = e.clientY || e.pageY; var objStyle = dragger.currentStyle || window.getComputedStyle(dragger,null); var objX = parseInt(objStyle.left) || 0; var objY = parseInt(objStyle.top) || 0; var limitX = mouseX - objX ; var limitY = mouseY - objY ; if(!dragger.onDrag){ dragger.onDrag = bindEvent(document,'onmousemove',function(e){ e = e || event; dragger.style.left = (e.clientX || e.pageX) - limitX + 'px'; dragger.style.top = (e.clientY || e.pageY) - limitY + 'px'; if(parseInt(dragger.style.left)<0){ dragger.style.left=0+"px"; } if(parseInt(dragger.style.left)>500){ dragger.style.left=500+"px"; } if(parseInt(dragger.style.top)>500){ dragger.style.top=500+"px"; } if(parseInt(dragger.style.top)<0){ dragger.style.top=0+"px"; } }); dragger.onDragEnd = bindEvent(document,'onmouseup',function(){ removeEvent(document,'onmousemove',dragger.onDrag); removeEvent(document,'onmouseup',dragger.onDragEnd); try{ delete dragger.onDrag; delete dragger.onDragEnd; }catch(e){ dragger.removeAttribute('onDrag'); dragger.removeAttribute('onDragEnd'); } }) } }) } __drag__(_$("dragger1"))(); </script> </body> </html>
上一篇:狡猾的按钮特效
下一篇:纯CSS实现右下角底部飘浮广告图片特效
免责声明:
本文仅代表作者个人观点,与爱易网无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
相关资料
更多>
《归来》遭视频网盗播 乐视网状告小米盒子侵权
微软很“捉急”:补贴Win8 重加末尾按钮
扎克伯格华裔妻子首度亮相电视节目畅谈情史
在线音乐出现“小米公司”不是没有可能
搜狐前副总编何毅加盟乐视 任车联网公司CEO
华为任正非:家族成员不会成为接班人
盘点改变社会的15种科技:谷歌眼镜将使我们成为半机械人
微软大幅调整Bing在华策略:从高大上到接地气
从雷军的“互联网七字诀”告诉你一个非妖魔化的小米
推荐阅读
更多>
支付宝27日晚间曝严重破绽:买卖记载可被搜索
联通丹东公司一高管造假套出手机变卖被判刑7年
地图导航骤起杀机 百度高德重新定义商业模式
唯品会荣登“最贵中概股”的欢喜与哀愁
华为变阵:任正非调整三大业务布局
阿里马云:我觉得互联网还有十年可以做
开个房刷个卡全世界都知道个人隐私成公开秘密
200美元英特尔Android笔记本行将到来
腾讯为何在与阿里百度的收购比赛中当看客?
三大运营商合建铁塔公司真相:未涉及电信业重组
优酷土豆兼并一年:依然处于烧钱形状
原万网CTO周雷加盟亿玛 出任CTO一职
中移动推动感地带3G网聊卡 火拼微信沃卡
郭美美事件推手被抓 “秦火火”拷问网络底线
王建宙解构OTT效劳 中移动重塑飞信平台
戴尔新CEO名单曝光:惠普甲骨文高管在列
用友软件股价逆势下跌 再融资方案现曙光
传苹果中移动达成协议:新iPhone兼容TD制式
京东封杀财付通:终极目标是电商生态圈
广东移动高层受调查 中移动或现更大反腐风暴