结合vue和纯css实现动态流量小球

前记

在数据可视化页面开发中,经常会有流量小球的开发需求。如何通过纯前端实现动态流量小球,而不需要使用设计小哥嗟来之图呢?

静态CSS实现波浪效果

探索前端实现波浪效果的过程中,我查阅到一些不同的实现方式,比如使用css库:CSS Trick(https://qishaoxuan.github.io/css_tricks/notCSS/wave.html);使用canvas画贝塞尔曲线等;或者干脆就是通过定时器循环移动一个svg或切图;

而最打动我的方式是https://github.com/chokcoco/iCSS/issues/22(chokcoco大神)的纯css实现波浪效果。

于是自己尝试着也实现一次。

  • 原理

如上图所示的流量小球,最主要的组成部分是蓝色部分的波浪,这部分通过css绘画似乎比较麻烦。于是我们反向思考,通过上层的圆角矩形遮挡,遮挡下层的纯蓝色底图的形式来实现。

  • 画图

这里先画了一个置于下层的蓝色圆球,然后通过伪元素设置倾斜角度、圆角和透明度不同的两个白色圆角矩形遮挡,初步实现了海浪的形状。

  • 动画

使用css动画animation属性,为两个矩形设置不同的旋转速度,海浪的动感就出来了。

调整其他css属性后,得到了流量小球的样式

设置变量

  • css变量

通过为小球遮罩层设置top属性,可以动态调整流量球流量大小。

声明css变量的时候,变量名前面要加两根连词线(–),然后使用var()函数读取变量。

这里需要注意下,css的变量名是大小写敏感的,

.wave::before,.wave::after{
  content: "";
  position: absolute;
  width: 400px;
  height: 400px;
  top: var(--ballPercent);   /* 变量 */
  left: 50%;
  background-color: rgba(0, 26, 46, .4);
  border-radius: 43%;
  transform: translate(-50%, -70%) rotate(0);
  animation: rotate 3s linear infinite;
  z-index: 10;
}
  • 在vue中

在data中同样定义一个ballPercent,来设置球体流量大小,

data() {
    return {
        ballPercent:50,// (100~0)
    }
},

然后将变量绑定在html中

<div class="wave" :style="{'--ballPercent': -ballPercent+40+'%'}"></div>

最后

加上数字等逻辑,流量小球就能根据后台数据变化时刻变化了。

  • 0
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 4
    评论
Vue提供了过渡动画的内置支持,可以通过Vue的transition组件来实现过渡动画。在transition组件中,可以定义进入动画、离开动画和过渡模式等。同时,CSS也提供了丰富的动画效果,可以通过CSS的transition属性来实现过渡动画。 下面是一个使用VueCSS实现过渡动画的示例: ```html <template> <div> <button @click="show = !show">Toggle</button> <transition name="fade"> <p v-if="show">Hello, World!</p> </transition> </div> </template> <style> .fade-enter-active, .fade-leave-active { transition: opacity 0.5s; } .fade-enter, .fade-leave-to { opacity: 0; } </style> <script> export default { data() { return { show: false }; } }; </script> ``` 在上面的示例中,我们定义了一个按钮和一个包裹着文本的transition组件。文本的显示与隐藏通过控制show属性来实现。同时,我们也定义了一个名为"fade"的transition,它定义了进入和离开动画的方式。 在CSS中,我们定义了两个类名为"fade-enter-active"和"fade-leave-active",它们分别表示进入和离开动画的状态。这里我们使用了CSS的transition属性,它指定了过渡的属性和时长。在这个例子中,我们使用opacity属性和0.5秒的时长来实现淡入淡出的效果。 同时,我们也定义了类名为"fade-enter"和"fade-leave-to",它们分别表示进入和离开动画的初始和结束状态。在这个例子中,我们将opacity属性的值设置为0,表示文本初始时是透明的,离开时也是透明的。 通过这样的方式,我们就可以使用VueCSS实现过渡动画了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值