基于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+jq创作含苞待放的荷花
Feb 20 HTML / CSS
CSS3实现瀑布流布局与无限加载图片相册的实例代码
Dec 22 HTML / CSS
css3实现书本翻页效果的示例代码
Mar 08 HTML / CSS
详解前端HTML5几种存储方式的总结
Dec 27 HTML / CSS
详解快速开发基于 HTML5 网络拓扑图应用
Jan 08 HTML / CSS
移动端Html5页面生成图片解决方案
Aug 07 HTML / CSS
详解如何解决canvas图片getImageData,toDataURL跨域问题
Sep 17 HTML / CSS
使用Html5多媒体实现微信语音功能
Jul 26 HTML / CSS
html5视频媒体标签video的使用方法及完整参数说明详解
Sep 27 HTML / CSS
用canvas显示验证码的实现
Apr 10 HTML / CSS
浅析HTML5页面元素及属性
Jan 20 HTML / CSS
CSS3实现三角形不断放大效果
Apr 13 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
非常精妙的PHP递归调用与静态变量使用
2012/12/16 PHP
PHP实现指定字段的多维数组排序函数分享
2015/03/09 PHP
php array_key_exists() 与 isset() 的区别
2016/10/24 PHP
Thinkphp3.2实用篇之计算型验证码示例
2017/02/09 PHP
才发现的超链接js导致网页中GIF动画停止的解决方法
2007/11/02 Javascript
使用jquery实现select添加实现后台权限添加的效果
2011/05/28 Javascript
JavaScript获取路径设计源码
2014/05/22 Javascript
jQuery插件开发的五种形态小结
2015/03/04 Javascript
解决node-webkit 不支持html5播放mp4视频的方法
2015/03/11 Javascript
详解参数传递四种形式
2015/07/21 Javascript
jquery.cookie.js用法实例详解
2015/12/25 Javascript
nodejs 中模拟实现 emmiter 自定义事件
2016/02/22 NodeJs
javascript实现数组去重的多种方法
2016/03/14 Javascript
原生js实现addClass,removeClass,hasClass方法
2016/04/27 Javascript
自动适应iframe右边的高度
2016/12/22 Javascript
bootstrap table实现双击可编辑、添加、删除行功能
2017/09/27 Javascript
Nginx 配置多站点vhost 的方法
2018/01/07 Javascript
微信小程序利用swiper+css实现购物车商品删除功能
2019/03/06 Javascript
解决Layui中layer报错的问题
2019/09/03 Javascript
JavaScript将数组转换为链表的方法
2020/02/16 Javascript
vue 解决无法对未定义的值,空值或基元值设置反应属性报错问题
2020/07/31 Javascript
Python实现字典的key和values的交换
2015/08/04 Python
python通过elixir包操作mysql数据库实例代码
2018/01/31 Python
python使用mysql的两种使用方式
2018/03/07 Python
python数字图像处理实现直方图与均衡化
2018/05/04 Python
python 每天如何定时启动爬虫任务(实现方法分享)
2018/05/21 Python
python 异或加密字符串的实例
2018/10/14 Python
python使用Paramiko模块实现远程文件拷贝
2019/04/30 Python
flask框架url与重定向操作实例详解
2020/01/25 Python
HTML5 图片预加载的示例代码
2020/03/25 HTML / CSS
化工专业应届生求职信
2013/11/08 职场文书
工作自我评价分享
2013/12/01 职场文书
安全资料员岗位职责范本
2014/06/28 职场文书
优质护理服务心得体会
2016/01/22 职场文书
Python机器学习三大件之一numpy
2021/05/10 Python
请求模块urllib之PYTHON爬虫的基本使用
2022/04/08 Python