学习网考试学习资料

Gzu521.com

用CSS层叠样式表完成可以控制的闪烁效果

CSS教程   点击:次   发布时间:2006-9-6   【字体: 】   来源:Gzu521.com
贵 州 学 习 网
一段文本或一张图片,它的周围有一圈光晕,这圈光晕每一秒钟闪烁一次,而当鼠标移到上面时,立即停止闪烁,当鼠标移开时又继续闪烁。这种效果用于那些需要特别引起别人注意的内容上(如:警示、报告新增内容等),能起到较好的效果。 

  上面这个示例就能实现上面所的效果,由于这里是抓取的一张图片,不能看到动态效果,只要按下面介绍的方法,制作一个试试,其效果是一目了然的。其制作思路是:采用了css的“glow”滤镜产生光晕效果,利用css的属性可动态改变的特性,用一小段javascript程序来每一秒钟改变一次属性值,从而实现闪烁的效果,再用两个事件(onmouseover和onmouseout)调用javascript程序来控制是否闪烁。 

  制作方法: 

  1、制作一个glow滤镜,css滤镜的设置方法请参看“css滤镜应用技巧”的有关文章。在此不再重复。不是使用dreamweaver的网友,请把下面的代码复制到网页源代码的〈head〉与〈/head〉之间: 

  〈style type="text/css"〉 

  〈!-- 

  .glow1 { filter:glow(color=#ff0000,strengh=2)} 

  --〉 

  〈/style〉 

  2、插入一个图层,取名为:bob。在图层上写上一段文字。再在图层上加载一个glow滤镜,并加上两个事件以实现当鼠标移到文字上时强制停止闪烁,当鼠标移开文字时继续闪烁。代码:onclick="stopflash(this)",这句代码的作用是:一旦鼠标移到文字上,将调用程序的“stopflash(this)”函数来停止闪烁; onmouseout="init()",这句代码的作用是:一旦鼠标移开文字,将调用程序的“init()”函数来使光晕闪烁。本例完成后图层标记的代码是这样的: 

  〈div id="bob" style="position:absolute; width:572px; height:35px; z-index:1" class="glow1" onmouseover="stopflash(this)" onmouseout="init()"〉 

  3、在〈head〉与〈/head〉之间插入这样一段javascript程序: 

  〈script 〉 

  〈!-- 

  function init() // 光晕开始闪烁 

  { 

  makeflash(bob); 

  } 

  function makeflash(obj) 

  { 

  obj.flashtimer=setinterval("bob.filters.glow.enabled= !bob.filters.glow.enabled",1000) 

  } // 这里的“1000”是闪烁的时间,以毫秒计,在本例中是设置了1000毫秒(即1秒),可以根据需要修改。 

  function stopflash(obj) // 光晕停止闪烁 

  { clearinterval(obj.flashtimer) 

  } 

  //--〉 

  〈/script〉 
  4、在网页源代码的〈body〉标记中加上这样一段代码:onload="init()"。这句代码的作用是当网页载入时,光晕开始闪烁。 

  至此,制作结束,按f12就可看到预期的效果了。 

  光晕的颜色和光晕的长度均可修改css滤镜中的参数值来改变,光晕闪烁的时间间隔可通过修改javascript中的间隔时间值来调整。若是在图层中插入图片(透明背景的gif图片效果更好),则变为图片边缘的光晕闪烁效果。 

责任编辑:gzu521

网页设计分类
HTML教程
CSS教程
Javascript教程
Dreamweaver教程
FrontPages教程
FireWorks教程
Flash教程
PhotoShop教程
建站知识
分类推荐信息
更多...
大类最新文章
更多...