css冒泡效果,使用动画实现

javascript 复制代码
<template>
  <div class="center">
    <div class="top">
      <div v-for="(i, index) in list" :key="index" class="top-box">
        <div class="bubble-box">
          <img :src="i.img" alt="" />
          <div class="bubbles">
            <div
              class="bubble"
              v-for="item in 10"
              :key="item"
              :style="{
                backgroundColor: i.color,
                animationDelay: getRandom() * 2 + 's',
                left: getRandom() * 10 + '%',
              }"
            ></div>
          </div>
        </div>
        <div class="text">
          <div class="num" :style="{ color: i.numColor }">{{ i.num }}</div>
          <div>{{ i.name }}</div>
        </div>
      </div>
    </div>
    
  </div>
</template>

<script>
export default {
  data() {
    return {
      list: [
        {
          img: "/img/dataCockpit/center1.png",
          num: 1643,
          numColor: "#2AD9F2",
          name: "名称1",
          color: "#aef5da",
        },
        {
          img: "/img/dataCockpit/center2.png",
          num: 22,
          numColor: "#53EA8C",
          name: "名称2",
          color: "#9efcff",
        },
        {
          img: "/img/dataCockpit/center3.png",
          num: 311,
          numColor: "#ffae00",
          name: "名称3",
          color: "#f5e88a",
        },
      ],
    };
  },
  methods: {
    getRandom() {
      return (Math.floor(Math.random() * 10) * 100) / 100;
    },
  },
};
</script>
<style lang="scss" scoped>
.center {
  padding-top: 35px;
  box-sizing: border-box;
  height: 100%;
  .top {
    background-image: url(/img/dataCockpit/centerTop.png);
    width: 856px;
    height: 115px;
    margin-bottom: 34px;
    color: #ffffff;
    font-size: 16px;
    display: flex;
    justify-content: space-between;
    padding: 0 70px;
    padding-bottom: 36px;
    padding-right: 88px;
    box-sizing: border-box;
    background-size: 100% 100%;
    align-items: center;
    margin-top: 20px;

    &-box {
      // position: relative;
      // top: -20px;
      display: flex;
      img {
        width: 105px;
        // height: 66px;
      }
      .text {
        height: 100%;
        padding-left: 15px;
        padding-bottom: 10px;
        box-sizing: border-box;
        // position: relative;
        // top: -10px;
        .num {
          font-size: 36px;
          font-weight: bold;
        }
      }
    }
  }
  .map {
    background-image: url(/img/dataCockpit/map.png);
    width: 892px;
    height: 656px;
    background-size: contain;
    position: relative;

    
  }
}
@keyframes flying {
  0% {
    bottom: 15px;
    transform: translateX(0);
  }
  50% {
    transform: translateX(50%);
  }
  100% {
    bottom: 200px;
    transform: translateX(-50%);
  }
}
.bubble-box {
  position: relative;
}
.bubbles {
  position: absolute;
  width: 100%;
  height: 100%;
  z-index: 0;
  overflow: hidden;
  top: 0;
  left: 0;
}
.bubble {
  position: absolute;
  bottom: 0;
  background: #f1f1f1;
  border-radius: 50%;
  opacity: 0.5;
  animation: flying 14s infinite ease-in;
  width: 5px;
  height: 5px;
  filter: blur(1px);
}
</style>
相关推荐
三十_A3 小时前
如何正确实现圆角渐变边框?为什么 border-radius 对 border-image 不生效?
前端·css·css3
jumu2024 小时前
3 次 B 样条优化:为你的 Matlab 程序加速
css
一水鉴天8 小时前
整体设计 定稿 之24 dashboard.html 增加三层次动态记录体系仪表盘 之2 程序 (Q208 之1)
前端·html
亮子AI8 小时前
【css】列表的标号怎么实现居中对齐?
前端·css
一水鉴天9 小时前
整体设计 定稿 之22 dashboard.html 增加三层次动态记录体系仪表盘 之1
前端·html
冰暮流星11 小时前
css3如何引入外部字体
前端·css·css3
lcc18711 小时前
CSS 选择器
css
李少兄12 小时前
前端开发中的 transform、translate 与 transition
前端·css
沟通QQ87622396513 小时前
有限元仿真模型仿真模型-基于COMSOL多物理场耦合仿真的变压器流固耦合及振动噪声分析 1、变...
html
李少兄13 小时前
深入理解前端中的透视(Perspective)
前端·css