jQuery UI API - 颜色动画(Color Animation)


jQuery UI 特效核心添加了使用 rgb()rgba()、十六进制值或者颜色名比如"aqua" 来动态改变 color 属性的功能。只需要包含 jQuery UI 特效核心文件,.animate() 就会支持颜色。

支持下列属性:

  • backgroundColor
  • borderBottomColor
  • borderLeftColor
  • borderRightColor
  • borderTopColor
  • color
  • columnRuleColor
  • outlineColor
  • textDecorationColor
  • textEmphasisColor

对颜色动画的支持来自 jQuery Color 插件。Color 插件提供了一些用于颜色的函数。如需查看完整文档,请访问 jQuery Color 文档

Class 动画(Class Animations)

虽然可以直接对 color 属性进行动画化,但是通常采用另一种更好的方法,即在一个 class 中包含样式。jQuery UI 提供了一些动态添加或去除 CSS 类的方法,分别是 .addClass().removeClass().toggleClass().switchClass()。这些方法将自动确定哪些属性需要改变,哪些需要应用适当的动画。

实例

  1. <!doctype html>
  2. <html lang="en">
  3. <head>
  4.   <meta charset="utf-8">
  5.   <title>颜色动画(Color Animation)演示</title>
  6.   <link rel="stylesheet" href="http://code.jquery.com/ui/1.10.4/themes/smoothness/jquery-ui.css">
  7.   <style>
  8.   #elem {
  9.     color: #006;
  10.     background-color: #aaa;
  11.     font-size: 25px;
  12.     padding: 1em;
  13.     text-align: center;
  14.   }
  15.   </style>
  16.   <script src="http://code.jquery.com/jquery-1.10.2.js"></script>
  17.   <script src="http://code.jquery.com/ui/1.10.4/jquery-ui.js"></script>
  18. </head>
  19. <body>
  20.  
  21. <div id="elem">颜色动画</div>
  22. <button id="toggle">改变颜色</button>
  23.  
  24. <script>
  25. $( "#toggle" ).click(function() {
  26.   $( "#elem" ).animate({
  27.     color: "green",
  28.     backgroundColor: "rgb( 20, 20, 20 )"
  29.   });
  30. });
  31. </script>
  32.  
  33. </body>
  34. </html>