css3伪类nth-child结合transiton动画实现文字若影若现
收先创建一个div盒子,然后包裹在div中的有10个span标签每个span标签填上内容一次为A,B,C,D,E,F,G,H,I,,J
先看下效果图:
看HTML5代码:
- <div class="box">
- <span>A</span>
- <span>B</span>
- <span>C</span>
- <span>D</span>
- <span>E</span>
- <span>F</span>
- <span>G</span>
- <span>H</span>
- <span>I</span>
- <span>J</span>
- </div>
复制代码
接下来给div添加一些css样式:
- .box {
- background-image: linear-gradient(135deg, #723362, #9d223c);
- color: #fff;
- padding: 1em 0;
- text-align: center;
- font-weight: 300;
- text-transform: uppercase;
- letter-spacing: .4em;
- padding-left: .4em;
- font-size: 1.8em;
- margin-top: 2.5rem
- }
复制代码
这里要说一点的就是linear-gradient(,,,)
共有三个参数,第一个参数表示线性渐变的方向,top 是从上到下、left 是从左到右,如果定义成 left top,那就是从左上角到右下角。这里定义的是一个角度135度,第二个和第三个参数分别是起点颜色和终点颜色。
然后背景角色设置为#9d223c
文字为白色,且居中显示,文字加粗显示,其中text-transform: uppercase表示的是文字只以大写字母开头进行旋转,其它的一些就不用多说了都是常见的一些属性什么内边距外边距啊字体大小啊等等。
下面才是真正进入主题部分:
来看下面代码:
- .box1 span {opacity: 0;transition: opacity 1300ms}
- .box:hover span {opacity: 1}
- .box span:nth-child(1) { transition-delay: 200ms }
- .box span:nth-child(2) { transition-delay: 1200ms }
- .box span:nth-child(3) { transition-delay: 800ms }
- .box span:nth-child(4) { transition-delay: 300ms }
- .box span:nth-child(5) { transition-delay: 700ms }
- .box span:nth-child(6) { transition-delay: 600ms }
- .box span:nth-child(7) { transition-delay: 400ms }
- .box span:nth-child(8) { transition-delay: 900ms }
- .box span:nth-child(9) { transition-delay: 700ms }
- .box span:nth-child(10) { transition-delay: 50ms }
复制代码
在设置完div的css样式后首先我们要给div下的span元素里的内容进行隐藏或者把他透明化,opacity:0表示的就是透明如果给他的值设置为1的话那就是不透明,当然你也可以设置为0.5或者0.3等等,opacity的值是0到1之间。
初始化设置透明为0后,在我们鼠标划过span元素的时候需要让再显示所以需要把透明度改为1
transition动画过度效果具体使用方法请看http://www.00h5.com/thread-15-1-1.html
其中transition-delay是transition的最后一个属性表示动画过度何时开始
再来看:nth-child,伪类选择器。
那么什么又是伪类?
伪类请看http://www.00h5.com/thread-76-1-1.html在这里我们用:nth-child来依次选择的设置span元素内容效果过渡,设置每个span的出现以及消失时间来达到效果。
最终完整代码:
- <!DOCTYPE html>
- <html lang="en">
- <head>
- <meta charset="UTF-8">
- <title>transition</title>
- <style>
- .box {
- background-image: linear-gradient(135deg, #723362, #9d223c);
- color: #fff;
- padding: 1em 0;
- text-align: center;
- font-weight: 300;
- text-transform: uppercase;
- letter-spacing: .4em;
- padding-left: .4em;
- font-size: 1.8em;
- margin-top: 2.5rem
- }
- .box span {opacity: 0;transition: opacity 1300ms}
- .box span:nth-child(1) { transition-delay: 200ms }
- .box span:nth-child(2) { transition-delay: 1200ms }
- .box span:nth-child(3) { transition-delay: 800ms }
- .box span:nth-child(4) { transition-delay: 300ms }
- .box span:nth-child(5) { transition-delay: 700ms }
- .box span:nth-child(6) { transition-delay: 600ms }
- .box span:nth-child(7) { transition-delay: 400ms }
- .box span:nth-child(8) { transition-delay: 900ms }
- .box span:nth-child(9) { transition-delay: 700ms }
- .box span:nth-child(10) { transition-delay: 50ms }
- .box:hover span {opacity: 1}
- </style>
- </head>
- <body>
- <div class="box">
- <span>A</span>
- <span>B</span>
- <span>C</span>
- <span>D</span>
- <span>E</span>
- <span>F</span>
- <span>G</span>
- <span>H</span>
- <span>I</span>
- <span>J</span>
- </div>
- </body>
- </html>
转自零零H5http://www.00h5.com/thread-676-1-1.html