网页跟随浮动层代码

在这个实例中,这个欢迎图标无论你怎样拉动滚动条,它都要跟着走,很难缠的哟!如果我想提醒浏览我的主页的网友一些事项或有其它什么声明,不妨用一用这个浮动层,让人家不得不看。


  第一步,将下列源代码加入html文件的<head>和</head>之间,并删除DW自动生成的头部声明文件:

<style type="text/css" media="screen">
#floater {
   position: absolute;
     width: 90;
   visibility: visible;
   z-index: 10;
}
-->
</style>
 
  上面这段代码规定浮动层的CSS属性,先是规定其位置属性为绝对的(absolute),然后规定坐标,再定义其为可见的(visible),最重要的是规定其z-index值,使这个图标始终置于最上层。

第二步,请将下列原代码加入body的任何地方(建议最后):

<div ID="floater" style="left: 590px; top: 158px">

<p align="center"><img SRC="
logo.gif
" title="欢迎光临">

<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 = document.body.scrollTop; diffX = document.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) document.all.floater.style.pixelTop += percent;
           if(NS) document.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) document.all.floater.style.pixelLeft += percent;
       if(NS) document.floater.left += percent;
       lastScrollX = lastScrollX + percent;
     }  
   }
   <!-- /STALKER CODE -->
   <!-- DRAG DROP CODE -->
   function checkFocus(x,y) {
   stalkerx = document.floater.pageX;
   stalkery = document.floater.pageY;
   stalkerwidth = document.floater.clip.width;
   stalkerheight = document.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 + document.body.scrollLeft);
       currentY = (event.clientY + document.body.scrollTop);  
     } else {
   window.captureEvents(Event.MOUSEMOVE);
   if(checkFocus (e.pageX,e.pageY)) {
   whichIt = document.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 + document.body.scrollLeft);
     newY = (event.clientY + document.body.scrollTop);
     distanceX = (newX - currentX); distanceY = (newY - currentY);
     currentX = newX; currentY = newY;
     whichIt.style.pixelLeft += distanceX;
     whichIt.style.pixelTop += distanceY;
       if(whichIt.style.pixelTop < document.body.scrollTop) whichIt.style.pixelTop = document.body.scrollTop;
       if(whichIt.style.pixelLeft < document.body.scrollLeft) whichIt.style.pixelLeft = document.body.scrollLeft;
       if(whichIt.style.pixelLeft > document.body.offsetWidth - document.body.scrollLeft - whichIt.style.pixelWidth - 20) whichIt.style.pixelLeft = document.body.offsetWidth - whichIt.style.pixelWidth - 20;
       if(whichIt.style.pixelTop > document.body.offsetHeight + document.body.scrollTop - whichIt.style.pixelHeight - 5) whichIt.style.pixelTop = document.body.offsetHeight + document.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>

posted @ 2008-09-25 14:02  净沙  阅读(2500)  评论(0编辑  收藏  举报