看到google今天的女生节Doodle,自己用纯css仿制一个,送给老妈、老婆、女儿。

大家可以点这里在线观看效果,点这里下载收藏效果

实现原理

1.利用checkbox侦听处理单击事件。

2.单击按钮、花、背景分别作盒子,公用背景并作背景偏移。

3.单击按钮之后,利用:checked伪类和兄弟选择符,为花、背景盒子作动画。

好的,来看html

  1. <input type="checkbox" id="play" />
  2. <div id="cont">
  3. <label id="btn" for="play"></label>
  4. <div id="circle"></div>
  5. </div>

css文件,具体参见注释。

  1. /* 设置容器 */
  2. #cont{
  3. width:482px;
  4. height:250px;
  5. background:url("http://www.google.com/logos/2014/womensday14/sprite-initial.png");
  6. background-position:-20px -10px;
  7. position:absolute;
  8. left:50%;
  9. top:50%;
  10. margin:-125px 0 0 -241px;
  11. }
  12. /* 设置按钮 */
  13. #btn{
  14. width:60px;
  15. height:78px;
  16. position:absolute;
  17. left:204px;
  18. top:64px;
  19. background:url("http://www.google.com/logos/2014/womensday14/sprite-initial.png");
  20. background-position:-1495px -110px;
  21. /* 确保垂直层次在#circle上面 */
  22. z-index:10;
  23. }
  24. #circle{
  25. /* 初始状态下,花不显示 */
  26. opacity:0;
  27. width:79px;
  28. height:79px;
  29. position:absolute;
  30. top:60px;
  31. left:184px;
  32. background:url("http://www.google.com/logos/2014/womensday14/sprite-initial.png");
  33. background-position:-1495px -190px;
  34. z-index:1;
  35. }
  36. /* hover状态下按钮样式 */
  37. #btn:hover{
  38. cursor:pointer;
  39. background-position:-1495px -30px;
  40. }
  41. /* 单击之后,按钮隐藏 */
  42. #play:checked~#cont #btn{
  43. display:none;
  44. }
  45. /* 单击之后,花显示,并轮转 */
  46. #play:checked~#cont #circle{
  47. opacity:1;
  48. animation:roll 1.8s linear infinite;
  49. }
  50. /* 单击之后,背景动画,这里偷了个懒,真比较少,注意一定是steps动画效果 */
  51. #play:checked~#cont{
  52. animation:run 1.2s steps(1,end) infinite;
  53. }
  54. @keyframes run{
  55. 0%{background-position:-20px -10px;}
  56. 33%{background-position:-521px -10px;}
  57. 66%{background-position:-1012px -10px;}
  58. 100%{background-position:-20px -10px;}
  59. }
  60. @keyframes roll{
  61. 0%{transform:rotate(0deg)}
  62. 100%{transform:rotate(360deg)}
  63. }

完工,请大家批评指正。

纯CSS仿制Google女生节Doodle的更多相关文章

  1. 使用纯 CSS 实现 Google Photos 照片列表布局

    文章太长,因为介绍了如何一步一步进化到最后接近完美的效果的,不想读的同学可以直接跳到最后一个大标题之后看代码.demo及原理就好,或者也可以直接看下面这个链接的源代码. 不过还是建议顺序读下去,因为后 ...

  2. 纯CSS无hacks的跨游览器多列布局

    利用纯CSS创建一个等高多列的布局并不件易事,本教程将着重分析出现在多列布局的多个问题,然后为大家等来一个简单全游览器通吃的解决方法,不使用图片,脚本,CSS hacks并在最严格的XHTML 规范中 ...

  3. 黑科技:纯CSS定制文本省略

    作者:weilong,腾讯 web前端开发 工程师 商业转载请联系腾讯WeTest获得授权,非商业转载请注明出处. WeTest导读 拿到设计MM的设计稿,Oh NO,点点点后面又双叒叕加内容了,弹丸 ...

  4. 纯css实现div中未知尺寸图片的垂直居中

    1.淘宝的方法 在曾经的"淘宝UED招聘"中有这样一道题目: “使用纯CSS实现未知尺寸的图片(但高宽都小于200px)在200px的正方形容器中水平和垂直居中.” 当然出题并不是 ...

  5. 纯CSS打造BiliBili样式博客主题

    前言 一直以来,我都在思考如何减少不必要的JS代码,仅通过CSS来实现博客园主题美化.CSS有很多魔法代码,例如:before,iconfont,order,等等,利用好这些技巧,也能实现很好美化效果 ...

  6. 谈谈一些有趣的CSS题目(八)-- 纯CSS的导航栏Tab切换方案

    开本系列,谈谈一些有趣的 CSS 题目,题目类型天马行空,想到什么说什么,不仅为了拓宽一下解决问题的思路,更涉及一些容易忽视的 CSS 细节. 解题不考虑兼容性,题目天马行空,想到什么说什么,如果解题 ...

  7. 一个标签的72变,打造一个纯CSS图标库

    每次要用到图标的时候都会到 icono 去copypaste,但每次用到的时候尺寸都各不一样,总是要调整参数,巨烦.当然你可以会想到用zoom.scale来做缩放,但是这样的缩放会使得线宽也变粗了,不 ...

  8. 利用animation和text-shadow纯CSS实现loading点点点的效果

    经常在网上看到loading状态时的点点点的动态效果,自己也用JS写了一个,思路是使用一个计数参数,然后在需要添加点的元素后面利用setInterval一个一个加点,当计数到3时,把点变为一个--写完 ...

  9. 使用纯CSS实现带箭头的提示框

    爱编程爱分享,原创文章,转载请注明出处,谢谢!http://www.cnblogs.com/fozero/p/6187323.html 1.全部代码 <!DOCTYPE html> < ...

随机推荐

  1. Java并发编程原理与实战四十一:重排序 和 happens-before

    一.概念理解 首先我们先来了解一下什么是重排序:重排序是指编译器和处理器为了优化程序性能而对指令序列进行重新排序的一种手段. 从Java源代码到最终实际执行的指令序列,会分别经历下面3种重排序,如下图 ...

  2. 【Codeforces858F】Wizard's Tour [构造]

    Wizard's Tour Time Limit: 50 Sec  Memory Limit: 512 MB Description Input Output Sample Input 4 5 1 2 ...

  3. 【leetcode 简单】 第七十二题 各位相加

    给定一个非负整数 num,反复将各个位上的数字相加,直到结果为一位数. 示例: 输入: 38 输出: 2 解释: 各位相加的过程为:3 + 8 = 11, 1 + 1 = 2. 由于 2 是一位数,所 ...

  4. vue_router 动态路由

    配置子路由: 路由的视图都需要使用view-router 子路由也可以嵌套路由使用: children来做嵌套如上图 使用location.页面name就可以做页面跳转 mounted:挂载,延迟跳转 ...

  5. python作业ATM(第五周)

    作业需求: 额度 15000或自定义. 实现购物商城,买东西加入 购物车,调用信用卡接口结账. 可以提现,手续费5%. 支持多账户登录. 支持账户间转账. 记录每月日常消费流水. 提供还款接口. AT ...

  6. [转]google gflags 库完全使用

    简单介绍 gflags 是 google 开源的用于处理命令行参数的项目. 安装编译 项目主页:gflags ➜ ~ git clone https://github.com/gflags/gflag ...

  7. Hibernate5笔记4--单表查询

    单表查询:   Hibernate是DAO层技术,对数据的使用,查询是最为重要的.Hibernate的查询技术非常强大,支持原始SQL语句查询,支持QBC查询及Hibernate特有的HQL查询. H ...

  8. C#匿名函数与Lambda表达式

    Lambda 表达式是一种可用于创建委托或表达式目录树类型的匿名函数. 通过使用 lambda 表达式,可以写入可作为参数传递或作为函数调用值返回的本地函数.在C#中的Linq中的大部分就是由扩展方法 ...

  9. Django中HttpRequest和HttpResponse

    请求和响应对象 Django中通过使用请求和响应对象来传递系统的状态. 当请求一个页面的时候,Django就创建一个HttpRequest对象,它包含了关于请求的元数据对象,然后Django加载适当的 ...

  10. 七、springcloud之配置中心Config(二)之高可用集群

    方案一:传统作法(不推荐) 服务端负载均衡 将所有的Config Server都指向同一个Git仓库,这样所有的配置内容就通过统一的共享文件系统来维护,而客户端在指定Config Server位置时, ...