基于CSS3的animation属性实现微信拍一拍动画效果


Posted in HTML / CSS onJune 22, 2020

看到最近流行的微信拍一拍功能,复习下CSS3的animation,所以写下这个盒子晃动的动画,把qq的窗口抖动也加上吧

@-webkit-keyframes shake {
    0% {
        -webkit-transform: translate(2px, 2px);
    }

    25% {
        -webkit-transform: translate(-2px, -2px);
    }

    50% {
        -webkit-transform: translate(0px, 0px);
    }

    75% {
        -webkit-transform: translate(2px, -2px);
    }

    100% {
        -webkit-transform: translate(-2px, 2px);
    }
}

@keyframes shake {
    0% {
        transform: translate(2px, 2px);
    }

    25% {
        transform: translate(-2px, -2px);
    }

    50% {
        transform: translate(0px, 0px);
    }

    75% {
        transform: translate(2px, -2px);
    }

    100% {
        transform: translate(-2px, 2px);
    }
}

.shake {
    position: relative;
    top: 30px;
    left: 100px;
    height: 200px;
    width: 200px;
    color: #ff0000;
    background: #000;
}

.shake:hover {
    -webkit-animation: shake 0.2s infinite;
    animation: shake 0.2s infinite;
}
 /*活动摇摆动画*/
 @-webkit-keyframes swing {
  10% {
    transform: rotate(15deg);
  }
  20% {
    transform: rotate(-10deg);
  }
  30% {
    transform: rotate(5deg);
  }
  40% {
    transform: rotate(-5deg);
  }
  50%,100% {
    transform: rotate(0deg);
  }
}
@-moz-keyframes swing {
  10% {
    transform: rotate(15deg);
  }
  20% {
    transform: rotate(-10deg);
  }
  30% {
    transform: rotate(5deg);
  }
  40% {
    transform: rotate(-5deg);
  }
  50%,100% {
    transform: rotate(0deg);
  }
}
@-o-keyframes swing {
  10% {
    transform: rotate(15deg);
  }
  20% {
    transform: rotate(-10deg);
  }
  30% {
    transform: rotate(5deg);
  }
  40% {
    transform: rotate(-5deg);
  }
  50%,100% {
    transform: rotate(0deg);
  }
}
@keyframes swing {
  10% {
    transform: rotate(12deg);
  }
  20% {
    transform: rotate(-11.5deg);
  }
  30% {
    transform: rotate(1deg);
  }
  40% {
    transform: rotate(-1deg);
  }
  50%,100% {
    transform: rotate(0.5deg);
  }
}
.stagger {
  background-color: #ff0000;
  width: 60px;
  height: 60px;
}
.stagger1{
  animation: swing .5s .15s linear 1;
  /* animation-play-state: paused; */
}
 <!-- qq窗口抖动 -->
  <div class="shake">qq窗口抖动</div>
  <!-- 微信拍拍头像晃动 -->
  <div class="stagger">微信拍拍头像晃动</div>
document.querySelector('.stagger').addEventListener('click', function() {
      document.querySelector('.stagger').classList.add('stagger1')
      console.log('papa nudged baby')
})
	/*每次点击实现动画,注意监听动画结束,移除动画类,后再添加动画类
    document.querySelector('.stagger').addEventListener('animationend', function() {
      document.querySelector('.stagger').classList.remove('stagger1')
    })

到此这篇关于基于CSS3的animation属性实现微信拍一拍动画效果的文章就介绍到这了,更多相关css3 微信拍一拍功能内容请搜索三水点靠木以前的文章或继续浏览下面的相关文章,希望大家以后多多支持三水点靠木!

HTML / CSS 相关文章推荐
CSS3 border-image详解、应用及jQuery插件
Aug 29 HTML / CSS
利用CSS3实现的文字定时向上滚动
Aug 29 HTML / CSS
利用Bootstrap实现漂亮简洁的CSS3价格表实例源码
Mar 02 HTML / CSS
CSS3实现酷炫的3D旋转透视效果
Nov 21 HTML / CSS
HTML5视频支持检测(检查浏览器是否支持视频播放)
Jun 08 HTML / CSS
canvas需要在标签里直接定义宽高
Dec 17 HTML / CSS
使用HTML5的Canvas绘制曲线的简单方法
Sep 08 HTML / CSS
HTML5实现页面切换激活的PageVisibility API使用初探
May 13 HTML / CSS
Html5新增标签有哪些
Apr 13 HTML / CSS
html5关于外链嵌入页面通信问题(postMessage解决跨域通信)
Jul 20 HTML / CSS
利用Node实现HTML5离线存储的方法
Oct 16 HTML / CSS
css样式important规则的正确使用方式
Jun 10 HTML / CSS
CSS3为背景图设置遮罩并解决遮罩样式继承问题
Jun 22 #HTML / CSS
CSS3 box-shadow属性实例详解
Jun 19 #HTML / CSS
CSS3新增布局之: flex详解
Jun 18 #HTML / CSS
如何使用css3实现一个类在线直播的队列动画的示例代码
Jun 17 #HTML / CSS
CSS3+JavaScript实现炫酷呼吸效果的示例代码
Jun 15 #HTML / CSS
CSS3中引入多种自定义字体font-face
Jun 12 #HTML / CSS
详解CSS3实现响应式手风琴效果
Jun 10 #HTML / CSS
You might like
用文本文件制作留言板提示(上)
2006/10/09 PHP
php模拟登陆的实现方法分析
2015/01/09 PHP
php+ajax实现无刷新动态加载数据技术
2015/04/28 PHP
PHP 设计模式系列之 specification规格模式
2016/01/10 PHP
PHP中strpos、strstr和stripos、stristr函数分析
2016/06/11 PHP
JavaScript实现删除电脑的关机键
2016/07/26 PHP
Yii2学习笔记之汉化yii设置表单的描述(属性标签attributeLabels)
2017/02/07 PHP
php利用ZipArchive类操作文件的实例
2020/01/21 PHP
javascript 火狐(firefox)不显示本地图片问题解决
2008/07/05 Javascript
google 搜索框添加关键字实现代码
2010/04/24 Javascript
网页上的Javascript编辑器和代码格式化
2010/04/25 Javascript
js函数返回多个返回值的示例代码
2013/11/05 Javascript
浅析IE10兼容性问题(frameset的cols属性)
2014/01/03 Javascript
JavaScript中的style.cssText使用教程
2014/11/06 Javascript
关于jQuery EasyUI 中刷新Tab选项卡后一个页面变形的解决方法
2017/03/02 Javascript
JavaScript 实现 Tab 点击切换实例代码
2017/03/25 Javascript
学习Vue组件实例
2018/04/28 Javascript
vuejs 动态添加input框的实例讲解
2018/08/24 Javascript
React 父子组件通信的实现方法
2019/12/05 Javascript
JSON stringify方法原理及实例解析
2020/10/23 Javascript
使用Python实现下载网易云音乐的高清MV
2015/03/16 Python
深度定制Python的Flask框架开发环境的一些技巧总结
2016/07/12 Python
python 垃圾收集机制的实例详解
2017/08/20 Python
人工智能最火编程语言 Python大战Java!
2017/11/13 Python
Django如何使用第三方服务发送电子邮件
2019/08/14 Python
Python队列、进程间通信、线程案例
2019/10/25 Python
Python字典深浅拷贝与循环方式方法详解
2020/02/09 Python
Python实现电视里的5毛特效实例代码详解
2020/05/15 Python
请用用Java代码写一个堆栈
2012/01/26 面试题
Java程序员面试90题
2013/10/19 面试题
大学生职业规划论文
2014/01/11 职场文书
《都江堰》教学反思
2014/02/07 职场文书
会计电算化毕业生自荐信
2014/03/03 职场文书
Mysql中存储引擎的区别及比较
2021/06/04 MySQL
Nginx 反向代理解决跨域问题多种情况分析
2022/01/18 Servers
面试中老生常谈的MySQL问答集锦夯实基础
2022/03/13 MySQL