Hello! 欢迎来到阿珏酱のBlog!

css

CSS3随机背景图片切换特效


avatar
阿珏 2018-05-16 5.63k

css3的随机背景图片淡入淡出切换特效  演示效果如本篇文章背景所示
看大家扒我的幻想领域二次元限定版扒的比较累,扒了大半个小时的,抽空整理一下发出来
设计之初本来是打算使用jQuery进行实现的,但是注意到了css3的@keyframes 规则,css3已经强大到曾经只有js才能实现的效果

定义和用法

通过 @keyframes 规则,您能够创建动画。

创建动画的原理是,将一套 CSS 样式逐渐变化为另一套样式。

在动画过程中,您能够多次改变这套 CSS 样式。

以百分比来规定改变发生的时间,或者通过关键词 “from” 和 “to”,等价于 0% 和 100%。

0% 是动画的开始时间,100% 动画的结束时间。

为了获得最佳的浏览器支持,您应该始终定义 0% 和 100% 选择器。

注释:请使用动画属性来控制动画的外观,同时将动画与选择器绑定。

核心css部分(记得切换图片地址)

复制代码
  1. body {
  2. background: #000;
  3. background-attachment: fixed;
  4. word-wrap: break-word;
  5. -webkit-background-size: cover;
  6. -moz-background-size: cover;
  7. background-size: cover;
  8. background-repeat: no-repeat
  9. }
  10.  
  11. ul {
  12. list-style: none
  13. }
  14.  
  15. .cb-slideshow li:nth-child(1) span {
  16. background-image: url(https://random.52ecy.cn/randbg.php?v=1520341099)
  17. }
  18.  
  19. .cb-slideshow li:nth-child(2) span {
  20. background-image: url(https://random.52ecy.cn/randbg.php?v=1520341159)
  21. }
  22.  
  23. .cb-slideshow li:nth-child(3) span {
  24. background-image: url(https://random.52ecy.cn/randbg.php?v=1520341149)
  25. }
  26.  
  27. .cb-slideshow li:nth-child(4) span {
  28. background-image: url(https://random.52ecy.cn/randbg.php?v=1520341139)
  29. }
  30.  
  31. .cb-slideshow li:nth-child(5) span {
  32. background-image: url(https://random.52ecy.cn/randbg.php?v=1520341129)
  33. }
  34.  
  35. .cb-slideshow li:nth-child(6) span {
  36. background-image: url(https://random.52ecy.cn/randbg.php?v=1520341119)
  37. }
  38.  
  39. .cb-slideshow,.cb-slideshow:after {
  40. position: fixed;
  41. width: 100%;
  42. height: 100%;
  43. top: 0;
  44. left: 0;
  45. z-index: -2
  46. }
  47.  
  48. .cb-slideshow:after {
  49. content: ''
  50. }
  51.  
  52. .cb-slideshow li span {
  53. width: 100%;
  54. height: 100%;
  55. position: absolute;
  56. top: 0;
  57. left: 0;
  58. color: transparent;
  59. background-size: cover;
  60. background-position: 50% 50%;
  61. background-repeat: none;
  62. opacity: 0;
  63. z-index: -2;
  64. -webkit-backface-visibility: hidden;
  65. -webkit-animation: imageAnimation 36s linear infinite 0s;
  66. -moz-animation: imageAnimation 36s linear infinite 0s;
  67. -o-animation: imageAnimation 36s linear infinite 0s;
  68. -ms-animation: imageAnimation 36s linear infinite 0s;
  69. animation: imageAnimation 36s linear infinite 0s
  70. }
  71.  
  72. .cb-slideshow li:nth-child(2) span {
  73. -webkit-animation-delay: 6s;
  74. -moz-animation-delay: 6s;
  75. -o-animation-delay: 6s;
  76. -ms-animation-delay: 6s;
  77. animation-delay: 6s
  78. }
  79.  
  80. .cb-slideshow li:nth-child(3) span {
  81. -webkit-animation-delay: 12s;
  82. -moz-animation-delay: 12s;
  83. -o-animation-delay: 12s;
  84. -ms-animation-delay: 12s;
  85. animation-delay: 12s
  86. }
  87.  
  88. .cb-slideshow li:nth-child(4) span {
  89. -webkit-animation-delay: 18s;
  90. -moz-animation-delay: 18s;
  91. -o-animation-delay: 18s;
  92. -ms-animation-delay: 18s;
  93. animation-delay: 18s
  94. }
  95.  
  96. .cb-slideshow li:nth-child(5) span {
  97. -webkit-animation-delay: 24s;
  98. -moz-animation-delay: 24s;
  99. -o-animation-delay: 24s;
  100. -ms-animation-delay: 24s;
  101. animation-delay: 24s
  102. }
  103.  
  104. .cb-slideshow li:nth-child(6) span {
  105. -webkit-animation-delay: 30s;
  106. -moz-animation-delay: 30s;
  107. -o-animation-delay: 30s;
  108. -ms-animation-delay: 30s;
  109. animation-delay: 30s
  110. }
  111.  
  112. @-webkit-keyframes imageAnimation {
  113. 0% {
  114. opacity: 0;
  115. -webkit-animation-timing-function: ease-in
  116. }
  117.  
  118. 8% {
  119. opacity: 1;
  120. -webkit-transform: scale(1.05);
  121. -webkit-animation-timing-function: ease-out
  122. }
  123.  
  124. 17% {
  125. opacity: 1;
  126. -webkit-transform: scale(1.1) rotate(0)
  127. }
  128.  
  129. 25% {
  130. opacity: 0;
  131. -webkit-transform: scale(1.1) rotate(0)
  132. }
  133.  
  134. 100% {
  135. opacity: 0
  136. }
  137. }

当然还是需要配合HTML代码的
HTML部分(其中的文字部分和<li>的数量是可以随意更改的)

复制代码
  1. <ul class="cb-slideshow">
  2. <li>
  3. <span>幻想</span></li>
  4. <li>
  5. <span>领域</span></li>
  6. <li>
  7. <span>一个</span></li>
  8. <li>
  9. <span>专业的</span></li>
  10. <li>
  11. <span>二次元</span></li>
  12. <li>
  13. <span>图床</span></li>
  14. </ul>

注意:<li>的数量要和css对应上,并且至少要两个以上。另外ie浏览器是不支持CSS3的特效

  • 苟利
  • 国家
  • 生死以
  • 岂能
  • 祸福
  • 趋避之

  • avatar
    游客

    这个怎么搞得了嘞?我研究了半天,还是全黑屏aru_15aru_15

    • avatar
      博主

      @ 凡人多烦事 @凡人多烦事:可以在群里at下我发个网址瞅瞅

      • avatar
        游客

        @ 阿珏 @阿珏:群里面那个是你呀?aru_15叫我主人还是本群群主aru_16

  • avatar
    游客

    翻牌子

  • avatar
    游客

    果然不能纯抄代码,第一行的background: #000;用了之后背景全黑没有特效,排查了后发现改成background-color:rgba(0,0,0,0);成功了,还有代码里缺分号作为一个强迫症的我有点不能接受。不过还是得感谢博主分享的特效代码!

    • avatar
      博主

      @ 我觉得不行 @我觉得不行:有些样式是要根据你实际情况更改的aru_36。css在线格式化后,默认最后一行样式都是不加分号的aru_11

  • avatar
    游客

    这图片无敌了

  • avatar
    游客

    审核元素,怎么屏蔽的,这个有点6,直接死机

  • avatar
    游客

    不能复制?那编写这篇文章干嘛?

    • avatar
      博主

      @ 腾讯视频 @腾讯视频:给你复制扒我文章?

      • avatar
        游客

        @ 阿珏 @阿珏:真要扒文章是个人都能做到吧,只是对于博客禁右感到莫名所以

  • avatar
    游客

    已解决,强制刷新CSS ver=

  • avatar
    游客

    换的是随机图API的链接 在360极速浏览器里不会刷新随机图

    • avatar
      博主

      @ 梦奴 @梦奴:被浏览器缓存了,加个时间戳就可以了

  • avatar
    游客

    可以,赞一个

发表评论
OωO表情

相关阅读

恰饭

欢迎阅读『CSS3随机背景图片切换特效 (゜-゜)つロ 干杯~』