dom元素+CSS实现阶梯动画效果

1.效果

2.代码实现

javascript 复制代码
<template>
  <div class="container">
    <div class="Box">
      <div class="box" style="background-color: red;"></div>
      <div class="box" style="background-color: orange;"></div>
      <div class="box" style="background-color: yellow;"></div>
      <div class="box" style="background-color: green;"></div>
      <div class="box" style="background-color: skyblue;"></div>
      <div class="box" style="background-color: blue;"></div>
    </div>
  </div>
</template>
<script>

export default {
  mounted () {
    this.setActions()
  },
  methods: {
    setActions () {
      //选中所有盒子
      const arr = document.querySelectorAll('.box')
 
 	  //循环添加事件监听
      arr.forEach(e => {
        e.addEventListener('mouseenter', () => {
          //通过添加类名实现盒子上移
          e.classList.add('boxMoveTwoStep')
          //判断前后的兄弟节点是否存在
          if (e.previousElementSibling) {//上一个节点
            e.previousElementSibling.classList.add('boxMoveOneStep')
          }
          if (e.nextElementSibling) {//下一个节点
            e.nextElementSibling.classList.add('boxMoveOneStep')
          }
        })
		//鼠标移除恢复盒子位置
        e.addEventListener('mouseleave', () => {
          e.classList.remove('boxMoveTwoStep')
          if (e.previousElementSibling) {
            e.previousElementSibling.classList.remove('boxMoveOneStep')
          }
          if (e.nextElementSibling) {
            e.nextElementSibling.classList.remove('boxMoveOneStep')
          }
        })
      })
    }
  }
}
</script>
<style lang='scss' scoped>
.container {
  width: 100%;
  height: 100%;
  overflow-y: hidden;
  position: relative;

  .Box {
    position: absolute;
    bottom: -50px;
    width: 100%;
    height: 100px;
  }

  .box {
    width: 50px;
    height: 100px;
    display: inline-block;
    background-color: pink;
    transition: 0.3s;
  }
}

.boxMoveOneStep {
  transform: translate(0px, -30px);
}

.boxMoveTwoStep {
  transform: translate(0px, -50px);
}
</style>
相关推荐
真的很上进13 分钟前
如何借助 Babel+TS+ESLint 构建现代 JS 工程环境?
java·前端·javascript·css·react.js·vue·html
web1309332039819 分钟前
vue elementUI form组件动态添加el-form-item并且动态添加rules必填项校验方法
前端·vue.js·elementui
NiNg_1_23440 分钟前
Echarts连接数据库,实时绘制图表详解
前端·数据库·echarts
如若1231 小时前
对文件内的文件名生成目录,方便查阅
java·前端·python
滚雪球~2 小时前
npm error code ETIMEDOUT
前端·npm·node.js
沙漏无语2 小时前
npm : 无法加载文件 D:\Nodejs\node_global\npm.ps1,因为在此系统上禁止运行脚本
前端·npm·node.js
supermapsupport2 小时前
iClient3D for Cesium在Vue中快速实现场景卷帘
前端·vue.js·3d·cesium·supermap
brrdg_sefg2 小时前
WEB 漏洞 - 文件包含漏洞深度解析
前端·网络·安全
胡西风_foxww2 小时前
【es6复习笔记】rest参数(7)
前端·笔记·es6·参数·rest
m0_748254882 小时前
vue+elementui实现下拉表格多选+搜索+分页+回显+全选2.0
前端·vue.js·elementui