[转载]JS拖动技术--- 关于setCapture
2011-09-03 11:52
531 查看
<script type="text/javascript">
<!--
window.onload=function(){
objDiv = document.getElementByIdx('drag');
drag(objDiv);
};
function drag(dv){
dv.onmousedown=function(e){
var
d=document;
e
= e || window.event;
var x= e.layerX || e.offsetX;
var
y= e.layerY || e.offsetY;
//设置捕获范围
if(dv.setCapture){
dv.setCapture();
}else
if(window.captureEvents){
window.captureEvents(Event.MOUSEMOVE | Event.MOUSEUP);
}
d.onmousemove=function(e){
e= e || window.event;
if(!e.pageX)e.pageX=e.clientX;
if(!e.pageY)e.pageY=e.clientY;
var tx=e.pageX-x;
var
ty=e.pageY-y;
dv.style.left=tx;
dv.style.top=ty;
};
d.onmouseup=function(){
//取消捕获范围
if(dv.releaseCapture){
dv.releaseCapture();
}else
if(window.captureEvents){
window.captureEvents(Event.MOUSEMOVE|Event.MOUSEUP);
}
//清除事件
d.onmousemove=null;
d.onmouseup=null;
};
};
}
//-->
</script>
--------
<div id="drag" >drag me <div>
--------------------------------------
setCapture
的意思就是设置一个对象的方法被触发的范围,或者作用域。
如果不设置,则div只在当前窗口内被触发。如果设置,则在整个浏览器范围内被触发,也就是可以拖到浏览器外面
<!--
window.onload=function(){
objDiv = document.getElementByIdx('drag');
drag(objDiv);
};
function drag(dv){
dv.onmousedown=function(e){
var
d=document;
e
= e || window.event;
var x= e.layerX || e.offsetX;
var
y= e.layerY || e.offsetY;
//设置捕获范围
if(dv.setCapture){
dv.setCapture();
}else
if(window.captureEvents){
window.captureEvents(Event.MOUSEMOVE | Event.MOUSEUP);
}
d.onmousemove=function(e){
e= e || window.event;
if(!e.pageX)e.pageX=e.clientX;
if(!e.pageY)e.pageY=e.clientY;
var tx=e.pageX-x;
var
ty=e.pageY-y;
dv.style.left=tx;
dv.style.top=ty;
};
d.onmouseup=function(){
//取消捕获范围
if(dv.releaseCapture){
dv.releaseCapture();
}else
if(window.captureEvents){
window.captureEvents(Event.MOUSEMOVE|Event.MOUSEUP);
}
//清除事件
d.onmousemove=null;
d.onmouseup=null;
};
};
}
//-->
</script>
--------
<div id="drag" >drag me <div>
--------------------------------------
setCapture
的意思就是设置一个对象的方法被触发的范围,或者作用域。
如果不设置,则div只在当前窗口内被触发。如果设置,则在整个浏览器范围内被触发,也就是可以拖到浏览器外面
相关文章推荐
- JS拖动技术--- 关于setCapture
- JS拖动技术--- 关于setCapture
- JS拖动技术--- 关于setCapture
- JS拖动技术--- 关于setCapture
- JS拖动技术 关于setCapture使用
- JS拖动技术--- 关于setCapture (转自 剑胆琴心-.Net学习笔记)
- JS高级拖动技术 setCapture,releaseCapture
- JS高级拖动技术 setCapture,releaseCapture-javascript技巧
- JS高级拖动技术--- setCapture ,releaseCapture
- JS高级拖动技术 setCapture,releaseCapture
- JS高级拖动技术 setCapture,releaseCapture
- [转载]关于VS05里checkboxlist用JS获取不到value值的解决方法
- 【转载】关于PHP的mod_rewrite重写模块技术个人觉得最好的一篇文章
- 理解 backbone.js 中的 bind 和 bindAll 方法,关于如何在方法中指定其中的 this,包含apply方法的说明[转载]
- 关于转载“一种新的穿透防火墙的数据传输技术”的一点看法
- 【转载】写一个js库需要怎样的知识储备和技术程度?
- 关于直播技术的转载
- <转载> 关于js常用方法的封装
- JS拖动–setCapture