原文地址:http://css3.bradshawenterprises.com/
转载自:http://sev7n.net/index.php/473.html
简介
本文 demo 主要演示了 CSS transitions, transforms (2D and 3D) 和 animations 属性,在当前(2010年11月),包括IE9在内的所有浏览器都支持了 2D transforms,transitions 也在除了IE内核外的所有浏览器(甚至在在开发版本)都可以使用了,而 3D transforms 和 animations 只有 Safari 和 Chrome 才支持。当然,大部分 demo 的浏览器降级都很优雅,即使还在用骨灰级浏览器你也可以在你的网站里使用 demo 里的代码,不过当然,动画你就没办法看到了。但是 3D transforms 一般没办法很好的优雅降级,不支持就是不支持,如果你要用还是注意点吧。
虽然我在 demo 里用 jQuery 添加和删除 class 来做了一些交互,但是所有的动画都不是用 javascript 实现的。而且在有些情况下你也可以用 :target 伪类选择器来代替 javascript,但是为了代码简洁我这里并没有使用。
如果你是用 iPhone OS,把 hover 出现的地方用 touch 和 hold 替换就可以了。(想知道怎么做类似的效果就仔细看下头部的 script )
为了使例子简单,在大部分的 transitions 中我只是用了两张图片来做效果演示,大部分 demo 都可以把图片换成更多好玩的内容(视频、文字等等)
值得注意的是这些动画在 iPhone OS 里都做了硬件加速,如果你正在开发一个手机站点建议你果断使用这些动画。
为了更方便的查看和复制源代码,我把 style 和 script 标签放在了每个 demo 前面的 section 里。这虽然是规范很不建议的,但是相信这会给你带来更多直接的好处,方便多了吧~(果然是用户第一啊)
点击 demos 页面 你可以找到更多demo,不过注释相对会少点。
目录
- 怎么使用 transitions
- 怎么使用 transforms
- 怎么使用 animations
- 图片切换
- hover 切换
- 点击切换
- 定时切换
- 不只是渐隐了
- 内容轮播
- transitions 轮播
- transitions + translations 轮播
- 内容翻转
- 手风琴
- 参考
怎么使用 transition
如果你以前没有用过 transition, 简短介绍下先
如果你想在一个节点有动画,添加下面的CSS:
- #id_of_element {
- -webkit-transition: all 1s ease-in-out;
- -moz-transition: all 1s ease-in-out;
- -o-transition: all 1s ease-in-out;
- transition: all 1s ease-in-out;
- }
因为浏览器厂商不一样,这里会有很多除了前缀外重复的东西 – 直到规范定稿前应该一直都会这样。如果你不想写这么多麻烦的东西,有很多工具可以帮你解决, 比如用 CSS Scaffold 你只要写一种混合东西就可以避免写这么多重复内容了.
transition 的语法很简单 – 动画属性, all 或者 border-radius 或者 color 或者其他东西, 动画时间, 然后是动画定时函数. 下面会说到动画定时函数的选项.
Demo
Ease
Ease In
Ease Out
Ease In Out
Linear
鼠标移上来
实际上不管在任何时间通过 hover 或者 javascript 设置新 class 来改变动画的不同属性,它都会平稳的从一个动画转换到另外一个。
你可以从这里找到更详细的资料 W3C specification.
怎么使用 transform
transform 共有两种分类 – 2D transforms 和 3D transforms.在2010年5月以前, 3D transforms 只有 Safari 才支持(包括 PC端和手机端). 而 2D transforms 已经被广泛支持了.
2D 例子
在去掉不同浏览器的前缀后这些效果的代码大概就是这样了:
- #skew {
- transform:skew(35deg);
- }
- #scale {
- transform:scale(1,0.5);
- }
- #rotate {
- transform:rotate(45deg);
- }
- #translate {
- transform:translate(10px, 20px);
- }
- #rotate-skew-scale-translate {
- transform:skew(30deg) scale(1.1,1.1) rotate(40deg) translate(10px, 20px);
- }
当然这些效果你也可以用transitions来实现动画 – 把鼠标移到下面的 div 看看.
3D 例子
3D transforms 你只有在 Safari 和 Chrome 下才看的到效果.
1
2
3
4
5
6
Perspective (43)
玩玩这个控制器 – 这里没有运用 transition , 只是做了滑动条来控制它. 请仔细看我只是用 javascript 来更新 css 的值 – 所有效果需要的数据全是浏览器自己算出来的.
怎么使用 animations
在2010年5月以前, 只有Webkit内核的浏览器才支持animations.
CSS animations 在2007年被Webkit浏览器引入,直到写这篇文章的时候仍然没有其他任何的浏览器来支持. Firefox 在执行起来有一个 bug, 但是它没有分配给任何人.
在 2009 年 animations 被写进了W3C网站上的 工作草案 .
在使用 CSS animation 前, 你首先得为动画指定一些关键帧 – 在一定时间时节点应该是什么样的效果,然后浏览器将会帮你做渐变来实现这个动画.
Demo
鼠标来吧
Code
这段代码的有意思之处就在于下面这段CSS:
- @-webkit-keyframes resize {
- 0% {
- padding: 0;
- }
- 50% {
- padding: 0 20px;
- background-color:rgba(255,0,0,0.2);
- }
- 100% {
- padding: 0 100px;
- background-color:rgba(255,0,0,0.9);
- }
- }
- #box {
- -webkit-animation-name: resize;
- -webkit-animation-duration: 1s;
- -webkit-animation-iteration-count: 4;
- -webkit-animation-direction: alternate;
- -webkit-animation-timing-function: ease-in-out;
- }
请注意,4个迭代(-webkit-animation-iteration-count: 4;)就可以让这个框转变2次 – 动画从前往后,然后再从后往前,周而复始就实现了这个动画效果
只要你喜欢你可以定义无数个关键帧和任何关键帧之间的时间间隔.
只要将 animation-iteration-count
设置成 infinite
, 动画就可以永远执行下去了.
Demo
实现这个动画的关键在于小的细节,不像上面框动那么大幅度!
图片切换
这个功能一般主要用于画廊的一部分,或者显示产品的详细内容. 传统的方法一般是用javascript控制内容的透明度 – 用 CSS transitions 就很简单了,你也很容易拿到自己的站点里去.
Demo 1 – 鼠标移上去切换图片 (transitions)
方案
- 把一张图片放到另一张的上面
- 当鼠标移上去的时候改变最上面图片的透明度
Demo
Code
首先写HTML结构. 没有调用CSS的时候你只能看到两张图片. 记得给使用的图片添加alt替换文字.
- <div id=“cf”>
- <img class=“bottom” src=“http://sev7n.net/demo/css3/images/Stones.jpg” />
- <img class=“top” src=“http://sev7n.net/demo/css3/images/Summit.jpg” />
- </div>
然后 CSS:
- #cf {
- position:relative;
- height:281px;
- width:450px;
- margin:0 auto;
- }
- #cf img {
- position:absolute;
- left:0;
- -webkit-transition: opacity 1s ease-in-out;
- -moz-transition: opacity 1s ease-in-out;
- -o-transition: opacity 1s ease-in-out;
- transition: opacity 1s ease-in-out;
- }
- #cf img.top:hover {
- opacity:0;
- }
Demo 2 – 点击按钮的时候切换图片(transitions)
方案
同样以前我们可能会用 :hover 来实现样式变化. 但是这里我用 jQuery 来添加和删除class,只是方便大家理解, 当然你也可以用源生的javascript.
Demo
点我就可以切换图片了
Code
首先HTML,同样没有CSS你只能看到两张图片
- <div id=“cf2″ class=“shadow”>
- <img class=“bottom” src=“http://sev7n.net/demo/css3/images/Stones.jpg” />
- <img class=“top” src=“http://sev7n.net/demo/css3/images/Summit.jpg” />
- </div>
- <p id=“cf_onclick”>Click me to toggle</p>
然后写 CSS. 添加一个透明的class.
- #cf2 {
- position:relative;
- height:281px;
- width:450px;
- margin:0 auto;
- }
- #cf2 img {
- position:absolute;
- left:0;
- -webkit-transition: opacity 1s ease-in-out;
- -moz-transition: opacity 1s ease-in-out;
- -o-transition: opacity 1s ease-in-out;
- transition: opacity 1s ease-in-out;
- }
- #cf2 img.transparent {
- opacity:0;
- }
- #cf_onclick {
- cursor:pointer;
- }
然后是简短的JS. 请注意浏览器已经足够智能,它可以用新的属性来实现这个动画, 我并没有用javascript来实现(虽然同样也可以实现).
- $(document).ready(function() {
- $(“#cf_onclick”).click(function() {
- $(“#cf2 img.top”).toggleClass(“transparent”);
- });
- });
你可以在 更多图片 demo 里看到怎么用这个方法实现更多图片切换的方法.
Demo 3 – 用定时器来实现图片切换 (transitions 和 animations,只支持 Webkit)
又是2010年5月以前, 只有 webkit 内核浏览器才支持 – 我只写了在webkit内核浏览器下实现的代码,如果你用其他浏览器,你就会看不到这个效果。
方案
你也可以用Javascript定时切换class来实现效果 – 在老的浏览器里也可以看到图片切换的效果. 但是既然我们在往前看,我们就用CSS 关键帧来做做看.
- 借用下 demo 1的代码
- 用 CSS 关键帧定义最顶部图片的两种状态, 透明和不透明.
- 设置动画的关键帧的参数.
Demo
每张图片显示9S之后就会切换到另外一张.
Code
所有的代码跟 Demo 1 一样, 我只是添加了一点 CSS
- @-webkit-keyframes cf3FadeInOut {
- 0% {
- opacity:1;
- }
- 45% {
- opacity:1;
- }
- 55% {
- opacity:0;
- }
- 100% {
- opacity:0;
- }
- }
- #cf3 img.top {
- -webkit-animation-name: cf3FadeInOut;
- -webkit-animation-timing-function: ease-in-out;
- -webkit-animation-iteration-count: infinite;
- -webkit-animation-duration: 10s;
- -webkit-animation-direction: alternate;
- }
为了实现这个效果,我定义了4个关键帧,特别定义不管动画怎么样在开始的45%时间内都保持不透明,在最后的45%时间内保持透明。动画会周而复始一直循环下去,每个过程持续10S。简单点说,图片1先保持4.5S的不透明,然后在1S内变成透明, 在接下来的4.5S内图片2将会一直显示. 反复、循环,这样图片1和图片2就会交替下去显示,每次显示9S(4.5 x 2).
Demo 4 – 不只是渐隐了
这项技术不止是局限于渐隐,你几乎可以让所有的属性动起来。这里还有2个例子.
放大和缩小
Safari 不怎么支持,但是在 Chrome & Webkit 下效果很不错。
鼠标移上来吧
旋转
鼠标思密达
内容滑动
在画廊和显示更多内容的时候我们经常可以看到滑动门,一般也是用javascript逐步改变关键迭代的padding值来实现。 但是用javascript来实现的在手机端看起来可能会有点卡,在动画太快的时候可能还会丢失一些帧。CSS transitions 加 transforms 就可以很简单的做这样的效果.
在 demos 页面你可以看到一个更完整的例子 .
Demo 1 – 通过增加padding 来实现滑动 (transitions)
在这篇文章里你可以看到: 跨浏览器实现滑动门.
方案
- 定义一个超出隐藏的容器.
- 在容器里定义另外一个跟所有图片大小一样的容器(容器2).
- 在容器2里,清除所有图片的padding和margin然后浮动
- 点击控制按钮的时候,改变容器2的left定位来显示需要的图片.
Demo
图片 1图片 2图片 3图片 4
Code
首先, HTML:
- <div id=“slide1_container”>
- <div id=“slide1_images”>
- <img src=“http://sev7n.net/demo/css3/images/Cirques.jpg” />
- <img src=“http://sev7n.net/demo/css3/images/Clown-Fish.jpg” />
- <img src=“http://sev7n.net/demo/css3/images/Stones.jpg” />
- <img src=“http://sev7n.net/demo/css3/images/Summit.jpg” />
- </div>
- </div>
- <p id=“slide1_controls”>
- <span id=“slide1-1″>Image 1</span>
- <span id=“slide1-2″>Image 2</span>
- <span id=“slide1-3″>Image 3</span>
- <span id=“slide1-4″>Image 4</span>
- </p>
然后 CSS:
- #slide1_controls span {
- padding-right:2em;
- cursor:pointer;
- }
- #slide1_container {
- width:450px;
- height:281px;
- overflow:hidden;
- position:relative;
- }
- #slide1_images {
- position:absolute;
- left:0px;
- width:1800px;
- -webkit-transition:all 1.0s ease-in-out;
- -moz-transition:all 1.0s ease-in-out;
- -o-transition:all 1.0s ease-in-out;
- -transition:all 1.0s ease-in-out;
- }
- #slide1_images img {
- padding:0;
- margin:0;
- float:left;
- }
同样,我用javascript给控制按钮绑定事件,我这里通过JS直接给容器添加了需要偏移的像素,当然也可以通过改变class来实现.
- $(document).ready(function() {
- $(“#slide1-1″).click(function() {
- $(“#slide1_images”).css(“left”,“0″);
- });
- $(“#slide1-2″).click(function() {
- $(“#slide1_images”).css(“left”,“-450px”);
- });
- $(“#slide1-3″).click(function() {
- $(“#slide1_images”).css(“left”,“-900px”);
- });
- $(“#slide1-4″).click(function() {
- $(“#slide1_images”).css(“left”,“-1350px”);
- });
- });
这段JS可以写的更优化也可以面向对象,为了保持代码简单就先这样吧.
Demo 2 – 通过 translate (transitions 和 transforms)来实现滑动
提示: iphone OS给转换过渡动画做了硬件加速,translate 也成了一个很好实现滑动的选择.
方案
- 跟demo 1一样,定义容器、超出隐藏
- 在容器里定义另外一个跟所有图片大小一样的容器(容器2).
- 在容器2里,清除所有图片的padding和margin然后浮动
- 就这里不同,点击控制按钮的时候不是改变容器2的left来显示需要的图片,而是 translate容器2.
Demo
图片 1图片 2图片 3图片 4
Code
几乎跟 Demo 1 一样, 只是JS有一点小区别: (不写那么多浏览器前缀了哈~)
- $(document).ready(function() {
- $(“#slide2-1″).click(function() {
- $(“#slide2_images”).css(“-webkit-transform”,“translate(0, 0)”);
- });
- $(“#slide2-2″).click(function() {
- $(“#slide2_images”).css(“-webkit-transform”,“translate(-450px, 0)”);
- });
- $(“#slide2-3″).click(function() {
- $(“#slide2_images”).css(“-webkit-transform”,“translate(-900px, 0)”);
- });
- $(“#slide2-4″).click(function() {
- $(“#slide2_images”).css(“-webkit-transform”,“translate(-1350px, 0)”);
- });
- });
内容翻转
良好的翻转需要浏览器支持 3D Transform – 目前只有 Safari. 但是你仍然可以看到翻转的效果,只是效果没有在Safari里那么绚!(比如chrome下面翻转的时候边缘会有锯齿)
Demo 1 – 翻转图片到内容节点 (transitions 和 3d transforms)
还是2010年5月以前, 这个属性只有 Webkit 和 Safari 才支持, 桌面端和手机端都可以,其他所有的浏览器都没法看到效果.
方案
- 在一个容器里把一张图片放到内容节点的上面.
- 把这个容器放在一个定义了perspective的容器里.
- 当鼠标移到外面容器的时候,让里面容器绕Y轴翻转.
Demo
这个属性对于显示图片详细内容很不错.
你可以放随便什么东西在这里.
Code
惯例, 结构先.
- <div id=“f1_container”>
- <div id=“f1_card” class=“shadow”>
- <div class=“front face”>
- <img src=“http://sev7n.net/demo/css3/images/Stones.jpg”/>
- </div>
- <div class=“back face center”>
- <p>This is nice for exposing more information about an image.</p>
- <p>Any content can go here.</p>
- </div>
- </div>
- </div>
然后 CSS
- #f1_container {
- position: relative;
- margin: 10px auto;
- width: 450px;
- height: 281px;
- z-index: 1;
- }
- .face.back {
- display: none;
- }
- #f1_container {
- -webkit-perspective: 1000;
- }
- #f1_card {
- width: 100%;
- height: 100%;
- -webkit-transform-style: preserve-3d;
- -webkit-transition: all 1.0s linear;
- }
- #f1_container:hover #f1_card {
- -webkit-transform: rotateY(180deg);
- -webkit-box-shadow: -5px 5px 5px #aaa;
- -moz-box-shadow: -5px 5px 5px #aaa;
- box-shadow: -5px 5px 5px #aaa;
- }
- .face {
- position: absolute;
- width: 100%;
- height: 100%;
- -webkit-backface-visibility: hidden;
- }
- .face.back {
- display: block;
- -webkit-transform: rotateY(180deg);
- -webkit-box-sizing: border-box;
- padding: 10px;
- color: white;
- text-align: center;
- background-color: #aaa;
- }
当然你也可以绕X轴或者Z轴旋转:
这里我必须改变阴影才能看起来是正常翻转.
这个属性对于显示图片详细内容很不错.
你可以放随便什么东西在这里.
手风琴
方案
- 定义几个有标题和内容的 section
- 给所有的section设置高度然后超出隐藏,除了第一个其他有内容的高度其他都只有标题的高度
- 给所有的标题绑定click事件来改变内容的高度
Demo
▶
一段长内容(打的乱七八糟内容)
Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Vestibulum tortor quam, feugiat vitae, ultricies eget, tempor sit amet, ante. Donec eu libero sit amet quam egestas semper. Aenean ultricies mi vitae est. Mauris placerat eleifend leo. Quisque sit amet est et sapien ullamcorper pharetra. Vestibulum erat wisi, condimentum sed, commodo vitae, ornare sit amet, wisi. Aenean fermentum, elit eget tincidunt condimentum, eros ipsum rutrum orci, sagittis tempus lacus enim ac dui. Donec non enim in turpis pulvinar facilisis. Ut felis. Praesent dapibus, neque id cursus faucibus, tortor neque egestas augue, eu vulputate magna eros eu erat. Aliquam erat volutpat. Nam dui mi, tincidunt quis, accumsan porttitor, facilisis luctus, metus
▶
一段短点的内容
Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Vestibulum tortor quam, feugiat vitae, ultricies eget, tempor sit amet, ante. Donec eu libero sit amet quam egestas semper. Aenean ultricies mi vitae est. Mauris placerat eleifend leo.
▶
两段短内容
Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Vestibulum tortor quam, feugiat vitae, ultricies eget, tempor sit amet, ante.
Pellentesque habitant morbi tristique senectus et netus et malesuada fames ac turpis egestas. Vestibulum tortor quam, feugiat vitae, ultricies eget, tempor sit amet, ante.
我不确定使用/滥用 Unicode 是不是一个好的办法, 但是你可以看到这样来实现手风琴确实相当简单.
这里我给不同的状态定义了不同的class,然后用jquery来添加或者删除这些class. 我们仍然可以用:target 伪类来做,这样就必须在点击的时候用 preventDefault() 阻止默认事件来防止页面上下跳转, 所以我干脆全用jQuery来写了.
The Code
HTML:
- <div id=“accordion”>
- <section id=“item1″>
- <p class=“pointer”>▶</p><h1><a href=“#”>A long paragraph</a></h1>
- <p>Pellentesque habitant… </p>
- </section>
- <section id=“item2″ class=“ac_hidden”>
- <p class=“pointer”>▶</p><h1><a href=“#”>A medium paragraph</a></h1>
- <p>Pellentesque habitant… </p>
- </section>
- <section id=“item3″ class=“ac_hidden”>
- <p class=“pointer”>▶</p><h1><a href=“#”>Two short paragraphs</a></h1>
- <p>Pellentesque habitant… </p>
- <p>Pellentesque habitant… </p>
- </section>
- </div>
CSS:
- #accordion section, #accordion .pointer, #accordion h1, #accordion p {
- -webkit-transition: all 0.5s ease-in-out;
- -moz-transition: all 0.5s ease-in-out;
- -o-transition: all 0.5s ease-in-out;
- transition: all 0.5s ease-in-out;
- }
- #accordion {
- margin-bottom:30px;
- }
- #accordion h1 {
- font-size:20px;
- background-color:rgba(255,0,0,0.3);
- margin:0;
- padding: 10px 10px 10px 30px;
- }
- #accordion h1 a {
- color:black;
- }
- #accordion section {
- overflow:hidden;
- height:220px;
- border:1px #333 solid;
- }
- #accordion p {
- padding:0 10px;
- color:black;
- }
- #accordion section.ac_hidden p:not(.pointer) {
- color:#fff;
- }
- #accordion section.ac_hidden {
- height:44px;
- }
- #accordion .pointer {
- padding:0;
- margin:10px 0 0 6px;
- line-height:20px;
- width:13px;
- position:absolute;
- }
- #accordion section:not(.ac_hidden) h1 {
- background-color:rgba(255,0,0,0.7);
- }
- #accordion section:not(.ac_hidden) .pointer {
- display:block;
- -webkit-transform:rotate(90deg);
- -moz-transform:rotate(90deg);
- -o-transform:rotate(90deg);
- transform:rotate(90deg);
- padding:0;
- }
添加一点 javascript 来添加和删除class.
- $(document).ready(function() {
- $(“#accordion section h1″).click(function(e) {
- $(this).parents().siblings(“section”).addClass(“ac_hidden”);
- $(this).parents(“section”).removeClass(“ac_hidden”);
- e.preventDefault();
- });
- });
参考
从下面你可以看到更多相关内容:
- W3C: CSS Transitions Module Level 3
- W3C: CSS 2D Transforms Module Level 3
- W3C: CSS 3D Transforms Module Level 3
- W3C: CSS Animations Module Level 3
- Surfin’ Safari (check the archives)
- CSS3 Transitions support in Opera Presto 2.3