爱易网
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 浏览次数:20233 次
以下是程序代码
<!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实现右下角底部飘浮广告图片特效
免责声明:
本文仅代表作者个人观点,与爱易网无关。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,请读者仅作参考,并请自行核实相关内容。
相关资料
更多>
京东封杀财付通:终极目标是电商生态圈
优酷土豆兼并一年:依然处于烧钱形状
App Store严禁推送广告 运用面临大清洗
移动联通回应税率改革:短期内收入利润将大减
搜房网遭遇做空 利益保送成“猎杀”焦点
IT企业人才争夺战打响:员工待遇水涨船高
惠普中国转型只是缩影 未来开展不可预期
三星石墨烯制备技术获突破
阿里国际化再落子:2.49亿美元投资新加坡邮政
推荐阅读
更多>
揭秘:阿里巴巴“无人认领”的三成股权都归谁
打车软件竞争白热化:有冷兵器时代意味
摩托罗拉移动裁员关闭德州Moto X手机工厂
牟贵先挂帅 国美在线“价钱战”昔日开打
传4G牌照国庆节前后发放 TD-LTE制式优先
O2O成"唐僧肉":百度糯米抢食第一口令阿里腾讯颤抖
支付宝全面封杀比特币:充值码淘宝店或遭封禁
只有切到刚需痛点,漫画APP才能走下去
虚拟运营商前路迷茫 业界建议发力车联网
京东联席董事长赵国庆上市前夕离职
搜狐与奇虎360或结盟对抗BAT
公信力消失:马航事件社交媒体传播之痛
阿里国际化再落子:2.49亿美元投资新加坡邮政
腾讯为何在与阿里百度的收购比赛中当看客?
NoomWeight减肥
窗口期:还有哪些互联网公司可能今年IPO?
PC迎9年来出货量新低 平板电脑渐成主流
HTC以品牌营销突围 专家建议改变经营思路
苹果大中华区业绩回暖 中移动贡献或低于预期
代工厂生活危机:“富士康们”何去何从?