規定區域的JS拖動展示效果


<html>
<head>
<title>規定區域的JS拖動展示效果</title>
<style>
body{background:#000; }
.box{
width:360px; 
height:360px; 
border:5px solid #555;
overflow:hidden; 
position:relative;
margin:0 auto; 
}
.box img{
cursor:move;
position:absolute; 
}
</style>
</head>
<body>
<div class="box" id="map"><img src="site.gif"></div>
</body>
<script>
function BuleJS(box) {
var _box = document.getElementById(box),el = _box.getElementsByTagName("IMG")[0],
r = el.offsetWidth - _box.offsetWidth,bi = el.offsetHeight - _box.offsetHeight;
function getXY(e) {
return e ? [e.pageX, e.pageY] : [event.clientX, event.clientY]
};
el.onmousedown = function(e) {
var a = getXY(e),b = [el.offsetLeft,el.offsetTop];
this.setCapture ? this.setCapture() : e.preventDefault();
document.onmousemove = function(e) {
var c = getXY(e);
el.style.left = Math.max( - r, Math.min(0, c[0] - a[0] + b[0]));
el.style.top = Math.max( - bi, Math.min(0, c[1] - a[1] + b[1]));
}
};
document.onmouseup = function(e) {
e || el.releaseCapture();
document.onmousemove = null;
}
};
BuleJS('map');
</script>
</html>
發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章