javascript 让所有页面内容都有淡入淡出效果

作者: Adam Michela     来源: axentric.com     时间: 2007-02-27 09:57:49
摘要: 关于淡入淡出效果的实现,本站已经有文章介绍过,而本文介绍的是通过 javascript ,让所有的页面内容(可以设置背景色的元素)都能有淡入淡出效果,而我们需要做的只是给需要效果的元素设置ID和 className 。按照一定规则,你可以随意定义淡入淡出的颜色。
归类: Javascript,

关键词: fade, 淡入, 淡出, javascript, 背景, 页面, 元素,


关于淡入淡出效果的实现,本站已经有文章介绍过,而本文介绍的是通过 javascript ,让所有的页面内容(可以设置背景色的元素)都能有淡入淡出效果,而我们需要做的只是给需要效果的元素设置ID和 className 。按照一定规则,你可以随意定义淡入淡出的颜色。


--------------------------------------------------------------
点此浏览示例文件
--------------------------------------------------------------


Javascript:
  1.  
  2. <script type="text/javascript">
  3. <!--
  4. // 说明:用 javascript 让所有页面内容都有淡入淡出效果
  5. // 整理:http://www.codebit.cn
  6.  
  7. // @name The Fade Anything Technique
  8. // @namespace http://www.axentric.com/aside/fat/
  9. // @version 1.0-RC1
  10. // @author Adam Michela
  11.  
  12. var Fat = {
  13. make_hex : function (r,g,b)
  14. {
  15. r = r.toString(16); if (r.length == 1) r = '0' + r;
  16. g = g.toString(16); if (g.length == 1) g = '0' + g;
  17. b = b.toString(16); if (b.length == 1) b = '0' + b;
  18. return "#" + r + g + b;
  19. },
  20. fade_all : function ()
  21. {
  22. var a = document.getElementsByTagName("*");
  23. for (var i = 0; i < a.length; i++)
  24. {
  25. var o = a[i];
  26. var r = /fade-?(\w{3,6})?/.exec(o.className);
  27. if (r)
  28. {
  29. if (!r[1]) r[1] = "";
  30. if (o.id) Fat.fade_element(o.id,null,null,"#"+r[1]);
  31. }
  32. }
  33. },
  34. fade_element : function (id, fps, duration, from, to)
  35. {
  36. if (!fps) fps = 30;
  37. if (!duration) duration = 3000;
  38. if (!from || from=="#") from = "#FFFF33";
  39. if (!to) to = this.get_bgcolor(id);
  40. var frames = Math.round(fps * (duration / 1000));
  41. var interval = duration / frames;
  42. var delay = interval;
  43. var frame = 0;
  44. if (from.length < 7) from += from.substr(1,3);
  45. if (to.length < 7) to += to.substr(1,3);
  46. var rf = parseInt(from.substr(1,2),16);
  47. var gf = parseInt(from.substr(3,2),16);
  48. var bf = parseInt(from.substr(5,2),16);
  49. var rt = parseInt(to.substr(1,2),16);
  50. var gt = parseInt(to.substr(3,2),16);
  51. var bt = parseInt(to.substr(5,2),16);
  52. var r,g,b,h;
  53. while (frame < frames)
  54. {
  55. r = Math.floor(rf * ((frames-frame)/frames) + rt * (frame/frames));
  56. g = Math.floor(gf * ((frames-frame)/frames) + gt * (frame/frames));
  57. b = Math.floor(bf * ((frames-frame)/frames) + bt * (frame/frames));
  58. h = this.make_hex(r,g,b);
  59. setTimeout("Fat.set_bgcolor('"+id+"','"+h+"')", delay);
  60.  
  61. frame++;
  62. delay = interval * frame;
  63. }
  64. setTimeout("Fat.set_bgcolor('"+id+"','"+to+"')", delay);
  65. },
  66. set_bgcolor : function (id, c)
  67. {
  68. var o = document.getElementById(id);
  69. o.style.backgroundColor = c;
  70. },
  71. get_bgcolor : function (id)
  72. {
  73. var o = document.getElementById(id);
  74. while(o)
  75. {
  76. var c;
  77. if (window.getComputedStyle) c = window.getComputedStyle(o,null).getPropertyValue("background-color");
  78. if (o.currentStyle) c = o.currentStyle.backgroundColor;
  79. if ((c != "" && c != "transparent") || o.tagName == "BODY") { break; }
  80. o = o.parentNode;
  81. }
  82. if (c == undefined || c == "" || c == "transparent") c = "#FFFFFF";
  83. var rgb = c.match(/rgb\s*\(\s*(\d{1,3})\s*,\s*(\d{1,3})\s*,\s*(\d{1,3})\s*\)/);
  84. if (rgb) c = this.make_hex(parseInt(rgb[1]),parseInt(rgb[2]),parseInt(rgb[3]));
  85. return c;
  86. }
  87. }
  88.  
  89. window.onload = function () {
  90. Fat.fade_all();
  91. }
  92. //-->
  93. </script>
  94.  



给你希望有淡入淡出效果的元素设置一个值为 fade 的 className,如:class="fade",默认的淡入淡出颜色是 #FFFF33,如果你想用其他颜色,只需要在 className 后面加上 "-你期望的颜色",如:class="fade-0000FF",这样的话,淡入淡出的颜色就是蓝色,是不是很方便?注意,元素一定要有 ID !


推荐链接:(联系 QQ :326801485)