纯CSS仿制Google女生节Doodle
看到google今天的女生节Doodle,自己用纯css仿制一个,送给老妈、老婆、女儿。
实现原理
1.利用checkbox侦听处理单击事件。
2.单击按钮、花、背景分别作盒子,公用背景并作背景偏移。
3.单击按钮之后,利用:checked伪类和兄弟选择符,为花、背景盒子作动画。
好的,来看html
- <input type="checkbox" id="play" />
- <div id="cont">
- <label id="btn" for="play"></label>
- <div id="circle"></div>
- </div>
css文件,具体参见注释。
- /* 设置容器 */
- #cont{
- width:482px;
- height:250px;
- background:url("http://www.google.com/logos/2014/womensday14/sprite-initial.png");
- background-position:-20px -10px;
- position:absolute;
- left:50%;
- top:50%;
- margin:-125px 0 0 -241px;
- }
- /* 设置按钮 */
- #btn{
- width:60px;
- height:78px;
- position:absolute;
- left:204px;
- top:64px;
- background:url("http://www.google.com/logos/2014/womensday14/sprite-initial.png");
- background-position:-1495px -110px;
- /* 确保垂直层次在#circle上面 */
- z-index:10;
- }
- #circle{
- /* 初始状态下,花不显示 */
- opacity:0;
- width:79px;
- height:79px;
- position:absolute;
- top:60px;
- left:184px;
- background:url("http://www.google.com/logos/2014/womensday14/sprite-initial.png");
- background-position:-1495px -190px;
- z-index:1;
- }
- /* hover状态下按钮样式 */
- #btn:hover{
- cursor:pointer;
- background-position:-1495px -30px;
- }
- /* 单击之后,按钮隐藏 */
- #play:checked~#cont #btn{
- display:none;
- }
- /* 单击之后,花显示,并轮转 */
- #play:checked~#cont #circle{
- opacity:1;
- animation:roll 1.8s linear infinite;
- }
- /* 单击之后,背景动画,这里偷了个懒,真比较少,注意一定是steps动画效果 */
- #play:checked~#cont{
- animation:run 1.2s steps(1,end) infinite;
- }
- @keyframes run{
- 0%{background-position:-20px -10px;}
- 33%{background-position:-521px -10px;}
- 66%{background-position:-1012px -10px;}
- 100%{background-position:-20px -10px;}
- }
- @keyframes roll{
- 0%{transform:rotate(0deg)}
- 100%{transform:rotate(360deg)}
- }
完工,请大家批评指正。
纯CSS仿制Google女生节Doodle的更多相关文章
- 使用纯 CSS 实现 Google Photos 照片列表布局
文章太长,因为介绍了如何一步一步进化到最后接近完美的效果的,不想读的同学可以直接跳到最后一个大标题之后看代码.demo及原理就好,或者也可以直接看下面这个链接的源代码. 不过还是建议顺序读下去,因为后 ...
- 纯CSS无hacks的跨游览器多列布局
利用纯CSS创建一个等高多列的布局并不件易事,本教程将着重分析出现在多列布局的多个问题,然后为大家等来一个简单全游览器通吃的解决方法,不使用图片,脚本,CSS hacks并在最严格的XHTML 规范中 ...
- 黑科技:纯CSS定制文本省略
作者:weilong,腾讯 web前端开发 工程师 商业转载请联系腾讯WeTest获得授权,非商业转载请注明出处. WeTest导读 拿到设计MM的设计稿,Oh NO,点点点后面又双叒叕加内容了,弹丸 ...
- 纯css实现div中未知尺寸图片的垂直居中
1.淘宝的方法 在曾经的"淘宝UED招聘"中有这样一道题目: “使用纯CSS实现未知尺寸的图片(但高宽都小于200px)在200px的正方形容器中水平和垂直居中.” 当然出题并不是 ...
- 纯CSS打造BiliBili样式博客主题
前言 一直以来,我都在思考如何减少不必要的JS代码,仅通过CSS来实现博客园主题美化.CSS有很多魔法代码,例如:before,iconfont,order,等等,利用好这些技巧,也能实现很好美化效果 ...
- 谈谈一些有趣的CSS题目(八)-- 纯CSS的导航栏Tab切换方案
开本系列,谈谈一些有趣的 CSS 题目,题目类型天马行空,想到什么说什么,不仅为了拓宽一下解决问题的思路,更涉及一些容易忽视的 CSS 细节. 解题不考虑兼容性,题目天马行空,想到什么说什么,如果解题 ...
- 一个标签的72变,打造一个纯CSS图标库
每次要用到图标的时候都会到 icono 去copypaste,但每次用到的时候尺寸都各不一样,总是要调整参数,巨烦.当然你可以会想到用zoom.scale来做缩放,但是这样的缩放会使得线宽也变粗了,不 ...
- 利用animation和text-shadow纯CSS实现loading点点点的效果
经常在网上看到loading状态时的点点点的动态效果,自己也用JS写了一个,思路是使用一个计数参数,然后在需要添加点的元素后面利用setInterval一个一个加点,当计数到3时,把点变为一个--写完 ...
- 使用纯CSS实现带箭头的提示框
爱编程爱分享,原创文章,转载请注明出处,谢谢!http://www.cnblogs.com/fozero/p/6187323.html 1.全部代码 <!DOCTYPE html> < ...
随机推荐
- bzoj千题计划143:bzoj1935: [Shoi2007]Tree 园丁的烦恼
http://www.lydsy.com/JudgeOnline/problem.php?id=1935 二维偏序问题 排序x,离散化树状数组维护y #include<cstdio> #i ...
- [Luogu 3258] JLOI2014 松鼠的新家
[Luogu 3258] JLOI2014 松鼠的新家 LCA + 树上差分. 我呢,因为是树剖求的 LCA,预处理了 DFN(DFS 序),于是简化成了序列差分. qwq不讲了不讲了,贴代码. #i ...
- Centos7 设置静态IP后重启网络服务出错
systemctl restart networkJob for network.service failed because the control process exited with erro ...
- 阿里云的OCS缓存机制
OCS简介 OCS( Open Cache Service)为分布式高速缓存服务,主要实现热点数据的快速响应: OCS支持Key/Value的数据结构,兼容memcachebinary protoco ...
- 训练赛第二场C题 zoj 2339 Hyperhuffman
题目链接:http://acm.zju.edu.cn/onlinejudge/showProblem.do?problemCode=2339 解题报告:题目太长了,比赛的时候根本看不懂,完了之后问了什 ...
- vi的复制粘贴命令 -- (转)
vi编辑器有3种模式:命令模式.输入模式.末行模式.掌握这三种模式十分重要: 1.命令模式:vi启动后默认进入的是命令模式,从这个模式使用命令可以切换到另外两种模式,同时无论在任何模式下只要按一下[E ...
- linux环境下mysql默认是区分表名大小写的
在linux环境下,mysql默认表明是区分大小写的,我们可以查看全局变量发现: mysql> show variables like 'lower%'; +------------------ ...
- 【Nginx】 Nginx实现端口转发
什么是端口转发 当我们在服务器上搭建一个图书以及一个电影的应用,其中图书应用启动了 8001 端口,电影应用启动了 8002 端口.此时如果我们可以通过 localhost:8001 //图书 loc ...
- jQuery动态给下拉列表添加一个选项(创建DOM对象)
使用的函数:
- NOIP 2016 迟来的满贯
17-03-22,雨 17-03-22,一个特别重要的日子 在这一天,本蒻攻克了NOIP 2016最难的一题,D1T2——天天爱跑步 实现了NOIP 2016的AK! YAYAYAYAYAYAY 自然 ...