其实属于DHTML的范围了,MSDN里面有一个部分全部介绍这个的,下面是网上找的代码,可以参考
有什么问题请到<a href='http://bbs.7dspace.com/index.asp?boardid=2'>论坛</a>中发表<br>
<!-- http://www.7dspace.com -->
<!-- bbs http://bbs.7dspace.com -->
<!--需要2步:
第一步,把下列代码加到<head>区域中-->
<head><style type="text/css">
#floater {
position: absolute;
left: 500;
top: 146;
width: 125;
visibility: visible;
z-index: 10;
}</style>
</head>
<!--第二步,把下列代码加到<body>区域中-->
<body>
<div ID="floater"
style="left: 590px;
top: 158px">
<p align="center"><img SRC="/files/pic/20050817/20058170220149895.gif"
alt="欢迎您来到七度空间"
WIDTH="125"
HEIGHT="60"><br>
<font color="#FF8040">七度空间</font></p>
</div><script LANGUAGE="JavaScript">
self.onError=null;
currentX = currentY = 0;
whichIt = null;
lastScrollX = 0;
lastScrollY = 0;
NS = (document.layers) ? 1 : 0;
IE = (document.all) ? 1: 0;
<!-- STALKER CODE -->
function heartBeat() {
if(IE) { diffY =do
cument.body.scrollTop;
diffX =do
cument.body.scrollLeft;
}
if(NS) { diffY = self.pageYOffset;
diffX = self.pageXOffset;
}
if(diffY != lastScrollY) {
percent = .1 * (diffY - lastScrollY);
if(percent > 0) percent = Math.ceil(percent);
else
percent = Math.floor(percent);
if(IE)do
cument.all.floater.style.pixelTop += percent;
if(NS)do
cument.floater.top += percent;
lastScrollY = lastScrollY + percent;
}
if(diffX != lastScrollX) {
percent = .1 * (diffX - lastScrollX);
if(percent > 0) percent = Math.ceil(percent);
else
percent = Math.floor(percent);
if(IE)do
cument.all.floater.style.pixelLeft += percent;
if(NS)do
cument.floater.left += percent;
lastScrollX = lastScrollX + percent;
}
}
<!-- /STALKER CODE -->
<!-- DRAG DROP CODE -->
function checkFocus(x,y) {
stalkerx =do
cument.floater.pageX;
stalkery =do
cument.floater.pageY;
stalkerwidth =do
cument.floater.clip.width;
stalkerheight =do
cument.floater.clip.height;
if( (x > stalkerx &&
x < (stalkerx+stalkerwidth)) &&
(y > stalkery &&
y < (stalkery+stalkerheight))) return true;
else
return false;
}
function grabIt(e) {
if(IE) {
whichIt = event.srcElement;
while (whichIt.id.indexOf("floater"
== -1) {
whichIt = whichIt.parentElement;
if (whichIt == null) { return true;
}
}
whichIt.style.pixelLeft = whichIt.offsetLeft;
whichIt.style.pixelTop = whichIt.offsetTop;
currentX = (event.clientX +do
cument.body.scrollLeft);
currentY = (event.clientY +do
cument.body.scrollTop);
} else
{
window.captureEvents(Event.MOUSEMOVE);
if(checkFocus (e.pageX,e.pageY)) {
whichIt =do
cument.floater;
StalkerTouchedX = e.pageX-document.floater.pageX;
StalkerTouchedY = e.pageY-document.floater.pageY;
}
}
return true;
}
function moveIt(e) {
if (whichIt == null) { return false;
}
if(IE) {
newX = (event.clientX +do
cument.body.scrollLeft);
newY = (event.clientY +do
cument.body.scrollTop);
distanceX = (newX - currentX);
distanceY = (newY - currentY);
currentX = newX;
currentY = newY;
whichIt.style.pixelLeft += distanceX;
whichIt.style.pixelTop += distanceY;
if(whichIt.style.pixelTop <do
cument.body.scrollTop) whichIt.style.pixelTop =do
cument.body.scrollTop;
if(whichIt.style.pixelLeft <do
cument.body.scrollLeft) whichIt.style.pixelLeft =do
cument.body.scrollLeft;
if(whichIt.style.pixelLeft >do
cument.body.offsetWidth -do
cument.body.scrollLeft - whichIt.style.pixelWidth - 20) whichIt.style.pixelLeft =do
cument.body.offsetWidth - whichIt.style.pixelWidth - 20;
if(whichIt.style.pixelTop >do
cument.body.offsetHeight +do
cument.body.scrollTop - whichIt.style.pixelHeight - 5) whichIt.style.pixelTop =do
cument.body.offsetHeight +do
cument.body.scrollTop - whichIt.style.pixelHeight - 5;
event.returnValue = false;
} else
{
whichIt.moveTo(e.pageX-StalkerTouchedX,e.pageY-StalkerTouchedY);
if(whichIt.left < 0+self.pageXOffset) whichIt.left = 0+self.pageXOffset;
if(whichIt.top < 0+self.pageYOffset) whichIt.top = 0+self.pageYOffset;
if( (whichIt.left + whichIt.clip.width) >= (window.innerWidth+self.pageXOffset-17)) whichIt.left = ((window.innerWidth+self.pageXOffset)-whichIt.clip.width)-17;
if( (whichIt.top + whichIt.clip.height) >= (window.innerHeight+self.pageYOffset-17)) whichIt.top = ((window.innerHeight+self.pageYOffset)-whichIt.clip.height)-17;
return false;
}
return false;
}
function dropIt() {
whichIt = null;
if(NS) window.releaseEvents (Event.MOUSEMOVE);
return true;
}
<!-- DRAG DROP CODE -->
if(NS) {
window.captureEvents(Event.MOUSEUP|Event.MOUSEDOWN);
window.onmousedown = grabIt;
window.onmousemove = moveIt;
window.onmouseup = dropIt;
}
if(IE) {
document.onmousedown = grabIt;
document.onmousemove = moveIt;
document.onmouseup = dropIt;
}
if(NS || IE) action = window.setInterval("heartBeat()",1);
</script>
</boyd>