爱易网
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 浏览次数:20254 次
以下是程序代码
<!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才能走下去
云智慧:用大数据实现企业应用性能管理
亚马逊宣布新春大促策略 欲打造另一个"黑五"
英特尔技术高管离任 电视业务或受影响
优酷土豆携手新浪微博 谋攻移动视频失地
空气污染器市场乱象丛生 选购需慎重
百视通:Xbox One汉化获批 游戏迷欢呼吧
马云:银行若放开存款利率 余额宝死了也光荣
腾讯为何在与阿里百度的收购比赛中当看客?
推荐阅读
更多>
微软最后的救命稻草Win 8份额继续上升
打车软件“明补变暗补”背后的小算盘
中国手游总裁及8名高管集体下岗,被指涉不当交易
从WPS到office365,中国企业能否赶超美国?
中国电信内外受困 去电信化思绪待改
原万网CTO周雷加盟亿玛 出任CTO一职
屌丝程序猿发家机会来了 用大数据来做生意!
三星维修新规:Galaxy S4主板进水也收费修
代工厂生活危机:“富士康们”何去何从?
盘点改变社会的15种科技:谷歌眼镜将使我们成为半机械人
传苹果已告知鸿海:两款新iPhone下月发货
开个房刷个卡全世界都知道个人隐私成公开秘密
200美元英特尔Android笔记本行将到来
中方抗议美方限购IT设备 紧张关系加剧
“合聚变”来了 UC优视确认并入阿里巴巴
为啥苹果定要出廉价iPhone?都是安卓逼的
谷歌新技术进入iOS平台:将叫板苹果Siri
二代 iPad Air将配备2GB内存?为同屏多任务做准备
都是300元内 乐视盒子与小米盒子对比体验
全球五大电信设备商业绩:华为净利居首