css3实现页面元素抖动效果

html

html 复制代码
<div id="shake" class="shape">horizontal shake</div>

js(vue3)

javascript 复制代码
  function shake(elemId) {
    const elem = document.getElementById(elemId)
    console.log('获取el', elem)

    if (elem) {
      elem.classList.add('shake')
      setTimeout(() => {
        elem.classList.remove('shake')
      }, 800)
    }
  }

  onMounted(() => {
    setTimeout(() => {
      console.log('进来settimeout')
      shake('shake')
    }, 5000)
  })

css

css 复制代码
  .shape {
    margin: 50px;
    width: 200px;
    height: 50px;
    line-height: 50px;
    text-align: center;
    border: 1px solid black;
  }
  .shake {
    animation: shake 800ms ease-in-out;
  }
  @keyframes shake {
    /* 水平抖动,核心代码 */
    10%,
    90% {
      transform: translate3d(-1px, 0, 0);
    }
    20%,
    80% {
      transform: translate3d(+2px, 0, 0);
    }
    30%,
    70% {
      transform: translate3d(-4px, 0, 0);
    }
    40%,
    60% {
      transform: translate3d(+4px, 0, 0);
    }
    50% {
      transform: translate3d(-4px, 0, 0);
    }
  }

参考链接:https://juejin.cn/post/6957517187049324552

相关推荐
Fan_web6 分钟前
jQuery——事件委托
开发语言·前端·javascript·css·jquery
安冬的码畜日常7 分钟前
【CSS in Depth 2 精译_044】第七章 响应式设计概述
前端·css·css3·html5·响应式设计·响应式
赛男丨木子丿小喵20 分钟前
visual studio2022添加新项中没有html和css
css·html·visual studio
莹雨潇潇1 小时前
Docker 快速入门(Ubuntu版)
java·前端·docker·容器
Jiaberrr1 小时前
Element UI教程:如何将Radio单选框的圆框改为方框
前端·javascript·vue.js·ui·elementui
Tiffany_Ho2 小时前
【TypeScript】知识点梳理(三)
前端·typescript
安冬的码畜日常3 小时前
【D3.js in Action 3 精译_029】3.5 给 D3 条形图加注图表标签(上)
开发语言·前端·javascript·信息可视化·数据可视化·d3.js
太阳花ˉ3 小时前
html+css+js实现step进度条效果
javascript·css·html
小白学习日记3 小时前
【复习】HTML常用标签<table>
前端·html