Javascript实现神奇的页面滚动控制

 Javascript实现神奇的页面滚动控制

首先,当我移动鼠标到这个指示器上面时,页面就会自动向上滚动,当移动鼠标到指示器下面时,页面就会自动向下滚动。我们不得不感叹新技术带来的神奇!它让我们费了更少的力气,完成同等的工作。但是,是否能在HTML页面上制作这样一个指示器呢?答案当然是:完全可以!请跟我来。

实现思路
 1、首先,准备好2个图形文件,一个代表向上,另一个代表向下。 
 2、然后,进行页面布局,我们可以将这个指示器图标放在你想要的任意位置,这里我们假设它位于当前窗口的右下部。 
 3、针对不同的浏览器,设置好相应的对象变量。这里,我们只考虑当前2种主流浏览器:IE和Netscape。 
 4、对2个指示器图标,分别设置onmouseover与onmouseout事件处理,生成当前操作状态。然后据此执行定时滚动函数,实现页面的滚动效果。

  1. < HTML >
  2.   < HEAD > 
  3.     < META http-equiv=Content-Type content="text/html; charset=gb2312" > 
  4.     < STYLE type=text/css > 
  5.       < !-- 
  6.         /*设置一个样式 
  7.         #item { LEFT: 0px; VISIBILITY: hidden; POSITION: absolute } 
  8.       -- > 
  9.     < /STYLE > 
  10.    
  11.     < SCRIPT language=JavaScript > 
  12.       < !--   
  13.         //设置变量 
  14.         //设置变量isNS,判别浏览器类型。对于NetScape浏览器,document.layers返回true值 
  15.         var isNS=(document.layers); 
  16.         //设置引用对象时的变量名称 
  17.         //对于IE浏览器,可见控制的引用值为document.all.object.style.visibility=visible 
  18.         //对于Ns浏览器,可见控制的引用值为document.object.visibility=show 
  19.         var _all=(isNS)? '' : 'all.' ; 
  20.         var _style=(isNS)? '' : '.style' ; 
  21.         var _visible=(isNS)? 'show' : 'visible'; 
  22.    
  23.         //设置其他变量:w_x与w_y:坐标值,okscroll:滚动与否,godown:是否向下 
  24.         var w_x, w_y, item, okscroll=false, godown; 
  25.    
  26.         //初始化运行函数 
  27.         function init()
  28.         {   
  29.           //将引用的对象赋值给item变量,这样,在随后的对象赋值操作中,可以简化代码的编写,并保持兼容性 
  30.           //注意:这是一个非常好的编程习惯 
  31.           item=eval('document.'+_all+'item'+_style); 
  32.           //取得当前窗口的尺寸大小等参数,并移动指示器到屏幕的右下角 
  33.           getwindowsize(); 
  34.    
  35.           //使指示器可见 
  36.           item.visibility=_visible
  37.    
  38.           //启动滚动判断定时函数,监测操作动作 
  39.           scrollpage(); 
  40.         } 
  41.    
  42.         //取得当前窗口大小参数,并根据这些数值移动指示器到屏幕右下角 
  43.         //注意:当用鼠标改变窗口的大小时,要根据当前最新的窗口长宽参数设置指示器的位置。否则,就可能看不到停留在 
  44.         //原来位置的指示器了。 
  45.         function getwindowsize()
  46.         {    
  47.           //对于IE,document.body.clientWidth表示当前窗口的宽度,document.body.clientHeight表示高度,单位是 
  48.           //象素px。如果是Ns浏览器,对应为window.innerWidth和window.innerHeight。 
  49.           w_x=(isNS)? window.innerWidth-5 : document.body.clientWidth; 
  50.           w_y=(isNS)? window.innerHeight : document.body.clientHeight; 
  51.    
  52.           //接着,设置代表指示器区域的层的宽度与高度。 
  53.           (isNS)? item.clip.width=42item.width=42
  54.           (isNS)? item.clip.height=20 : item.height=20
  55.    
  56.           //根据上面设置的参数,移动指示器到相应位置 
  57.           moveitem(); 
  58.         } 
  59.    
  60.         //移动指示器 
  61.         function moveitem() 
  62.         { 
  63.    
  64.           //对于NS浏览器 
  65.           if (isNS) 
  66.           { 
  67.              item.moveTo((pageXOffset+w_x-70),(w_y+pageYOffset-50)) 
  68.           }
  69.           else
  70.           { 
  71.              //如果是IE,直接给层的2个属性赋值:pixelLeft代表X坐标,pixelTop代表Y坐标 
  72.              //注意:当屏幕发生滚动时,document.body.scrollLeft与document.body.scrollTop分别代表 
  73.              //滚动的横向距离与纵向距离。而w_x与w_y分别表示了指示器在当前窗口的相对坐标位置, 
  74.              //所以,要对2者进行相加操作,从而得到指示器的绝对坐标位置。 
  75.              item.pixelLeft=document.body.scrollLeft+w_x-70; 
  76.              item.pixelTop=w_y+document.body.scrollTop-50; 
  77.           } 
  78.         } 
  79.    
  80.         //对于Ns浏览器,当窗口大小变化时,执行定时操作 
  81.         function resizeNS() 
  82.         { 
  83.            //setTimeout函数设置了定时执行的操作,这里表示:每400毫秒执行document.location.reload()操作 
  84.            setTimeout('document.location.reload()',400); 
  85.         }
  86.         //页面滚动控制函数 
  87.         function scrollpage() 
  88.         {
  89.            status = ''
  90.            //okscroll与godown都是滚动状态标志,其值由指示器层的onmouseover与onmouseout2个事件控制。 
  91.            //window.scrollBy(x,y)控制页面滚动,x、y分别表示横向与纵向滚动的距离,单位是象素px。 
  92.            //当设置y值更大时,每次滚动的距离也将更大。 
  93.            if (okscroll) 
  94.            { 
  95.              if (godown)
  96.              { 
  97.                  (isNS)? window.scrollBy(0,4) : window.scrollBy(0,4) ; 
  98.              } else { 
  99.                  (isNS)? window.scrollBy(0,-4) : window.scrollBy(0,-4) ; 
  100.              } 
  101.            } 
  102.    
  103.            //页面滚动后,指示器已不再停留在我们期待的位置。所以,要再次执行移动函数移动它到屏幕的右下角。 
  104.            //这样,看起来好像它总是在那里 ;-) 
  105.            moveitem(); 
  106.    
  107.            //设置滚动函数定时执行。这里的时间,表示了监测用户操作状态的周期,越小表示越精确,但程序也将 
  108.            //更“忙”。设置得过于长,就会产生慢动作的延迟效果,好像计算机很迟钝,当我们将鼠标点到向下指示器 
  109.            //时,屏幕并没有马上做出反应,而是等了一段时间,才向下滚动 ;-( 
  110.            //根据你的需要,并进行测试,设置这个数值。 
  111.            setTimeout('scrollpage()', 158); 
  112.         } 
  113.    
  114.         //页面加载后,启动相关脚本函数 
  115.         //设置页面加载后,首先启动init函数 
  116.         window.onload=init
  117.    
  118.        //设置当窗口大小发生变换时启动的函数 
  119.        (isNS) ? window.onresize=resizeNS : window.onresize=getwindowsize ; 
  120.    
  121.       // End -- > 
  122.     </SCRIPT> 
  123.   </HEAD> 
  124.   < BODY >    
  125.     <!--用div标记定义一个层,从而可以在脚本程序中对它进行控制--> 
  126.     <!--接着,给指示器图像添加2个事件,当它们发生时,分别设置相应的操作状态变量--> 
  127.     < DIV id=item >
  128.        < A onmouseover="okscroll=true; godown=true;" onmouseout=okscroll=false href="javascript:void(0)" >
  129.          < IMG src="http://www.webjx.com/htmldata/2005-06-15/down.gif" border=0 />
  130.       </A>
  131.       <A onmouseover="okscroll=true; godown=false;" onmouseout=okscroll=false href="javascript:void(0)" >
  132.         < IMG src="http://www.webjx.com/htmldata/2005-06-15/up.gif" border=0 />
  133.       </A >
  134.     < /DIV > 
  135.     <P> 
  136.        <!--以下是页面内容,写得长一些,从而能看到操作效果--> 
  137.        < CENTER >◆◆◆◆◆ Begin From Here ◆◆◆◆◆ 
  138.          < P >用JavaScript制作页面滚动效果 
  139.          < P >用JavaScript制作页面滚动效果 
  140.          < P >用JavaScript制作页面滚动效果 
  141.          < P >用JavaScript制作页面滚动效果 
  142.          < P >用JavaScript制作页面滚动效果 
  143.          < P >用JavaScript制作页面滚动效果 
  144.          < P >用JavaScript制作页面滚动效果 
  145.          < P >用JavaScript制作页面滚动效果 
  146.          < P >用JavaScript制作页面滚动效果 
  147.          < P >用JavaScript制作页面滚动效果 
  148.          < P >用JavaScript制作页面滚动效果 
  149.          < P >用JavaScript制作页面滚动效果 
  150.          < P >用JavaScript制作页面滚动效果 
  151.          < P >用JavaScript制作页面滚动效果 
  152.          < P >用JavaScript制作页面滚动效果 
  153.          < P >用JavaScript制作页面滚动效果 
  154.          < P >用JavaScript制作页面滚动效果 
  155.          < P >用JavaScript制作页面滚动效果 
  156.          < P >用JavaScript制作页面滚动效果 
  157.          < P >用JavaScript制作页面滚动效果 
  158.          < P >用JavaScript制作页面滚动效果 
  159.          < P >用JavaScript制作页面滚动效果 
  160.          < P >用JavaScript制作页面滚动效果 
  161.          < P >用JavaScript制作页面滚动效果 
  162.          < P >用JavaScript制作页面滚动效果 
  163.          < P >用JavaScript制作页面滚动效果 
  164.          < P >用JavaScript制作页面滚动效果 
  165.          < P >用JavaScript制作页面滚动效果 
  166.          < P >◆◆◆◆◆ End Here ◆◆◆◆◆ 
  167.          < P >
  168.        < /CENTER > 
  169.     </P >
  170.   </BODY >
  171. </HTML > 

http://www.haohao888.com.cn/wzjs/HTML/4545_6.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值