基于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 HSLA色彩模式?HSLA模拟渐变色条
Apr 26 HTML / CSS
纯CSS3绘制打火机动画火焰效果
Jul 18 HTML / CSS
利用CSS3 动画 绘画 圆形动态时钟
Mar 20 HTML / CSS
详解css3中 text-fill-color属性
Jul 08 HTML / CSS
纯HTML5+CSS3制作生日蛋糕代码
Nov 16 HTML / CSS
HTML5 Web 存储详解
Sep 16 HTML / CSS
canvas需要在标签里直接定义宽高
Dec 17 HTML / CSS
利用HTML5中的Canvas绘制一张笑脸的教程
May 07 HTML / CSS
利用HTML5实现使用按钮控制背景音乐开关
Sep 21 HTML / CSS
HTML5标签使用方法详解
Nov 27 HTML / CSS
浅谈html5增强的页面元素
Jun 14 HTML / CSS
Canvas在超级玛丽游戏中的应用详解
Feb 06 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
使用迭代器 遍历文件信息的详解
2013/06/08 PHP
php实现多城市切换特效
2015/08/09 PHP
Zend Framework教程之分发器Zend_Controller_Dispatcher用法详解
2016/03/07 PHP
Laravel框架分页实现方法分析
2018/06/12 PHP
PHP实现打包zip并下载功能
2018/06/12 PHP
php web环境和命令行环境下查找php.ini的位置
2019/07/17 PHP
关于js中window.location.href,location.href,parent.location.href,top.location.href的用法与区别
2010/10/18 Javascript
jquery构造器的实现代码小结
2011/05/16 Javascript
js动态创建表格,删除行列的小例子
2013/07/20 Javascript
JS中的异常处理方法分享
2013/12/22 Javascript
Javascript闭包(Closure)详解
2015/05/05 Javascript
javascript常用函数(2)
2015/11/05 Javascript
Bootstrap布局组件应用实例讲解
2016/02/17 Javascript
Javascript 6里的4个新语法
2016/08/25 Javascript
javascript随机变色实例代码
2019/10/15 Javascript
JS实现随机抽选获奖者
2019/11/07 Javascript
vue-autoui自匹配webapi的UI控件的实现
2020/03/20 Javascript
Vue如何提升首屏加载速度实例解析
2020/06/25 Javascript
Python中用format函数格式化字符串的用法
2015/04/08 Python
用Python获取摄像头并实时控制人脸的实现示例
2019/07/11 Python
Django Session和Cookie分别实现记住用户登录状态操作
2020/07/02 Python
linux面试题参考答案(9)
2015/01/07 面试题
AJAX应用和传统Web应用有什么不同
2013/08/24 面试题
工程专业应届生求职信
2014/02/19 职场文书
八项规定整改方案
2014/02/21 职场文书
人力资源部门的主要职能
2014/02/22 职场文书
计算机维护专业推荐信
2014/02/27 职场文书
计算机科学系职业生涯规划书
2014/03/08 职场文书
优秀少先队员主要事迹材料
2014/05/28 职场文书
施工安全责任书范本
2014/07/24 职场文书
2014年仓库保管员工作总结
2014/12/03 职场文书
应届毕业生求职简历自我评价
2015/03/02 职场文书
撤诉申请怎么写
2015/05/19 职场文书
python实现进度条的多种实现
2021/04/29 Python
vue 实现弹窗关闭后刷新效果
2022/04/08 Vue.js
JS前端使用canvas实现物体的点选示例
2022/08/05 Javascript