前记

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

静态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>

最后

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

结合vue和纯css实现动态流量小球相关推荐

  1. before css 旋转_单标签!纯CSS实现动态晴阴雨雪

    引言 本期分享一下如何仅用CSS3,实现单标签的动态晴阴雨雪.技术关键点就是"单标签"和"纯CSS".先看下最终效果: 再看看HTML代码: <div c ...

  2. 纯CSS实现动态晴阴雨雪

    1 引言 本期分享一下如何仅用CSS3,实现单标签的动态晴阴雨雪.技术关键点就是"单标签"和"纯CSS".先看下最终效果: 再看看HTML代码: <!-- ...

  3. html怎么把字做成动画效果,利用纯CSS实现动态的文字效果实例

    大家可能经常会看到类似酷炫的网站: 在这类网站中能看到,一打开页面,无论是文字还是图片,都随着规定时间的而变化.原理很简单,主要用到CSS中animation属性. 接下来,我以我目前的工程项目为例, ...

  4. php动态字体,利用纯CSS实现动态的文字效果实例

    相信大家都曾在网站中看到过中效果,一打开页面,无论是文字还是图片,都随着规定时间的而变化,今天我们将介绍如何通过用纯CSS来实现这种效果,下面一起来看看. 大家可能经常会看到酷炫的网站 在这类网站中能 ...

  5. html如何动态显示天气,纯CSS实现动态的天气图标

    单标签!纯CSS实现动态晴阴雨雪 .weather { position: relative; display: inline-block; width: 180px; height: 240px; ...

  6. 前端学习——纯CSS实现动态翻转导航条

    纯CSS实现动态翻转导航条 在学习动画的时候,一开始不知道写一个生命东西来进行学习,后来在网上看到了一些CSS实现的动画效果,觉得很酷炫,就在其中选了导航条来进行学习,导航条比较基础而且用的比较多,以 ...

  7. 有趣的纯CSS实现动态晴阴雨雪

    我们先来看看实现的效果吧 非常的美腻,对吧.这个是纯css,且单标签实现的哦~ 先贴完整代码,我们再来看看这个里面究竟有什么可以借鉴的知识点 <!DOCTYPE html> <htm ...

  8. 单标签实现纯CSS实现动态晴阴雨雪

    1 引言 本期分享一下如何仅用CSS3,实现单标签的动态晴阴雨雪.技术关键点就是"单标签"和"纯CSS".先看下最终效果: 再看看HTML代码: <!-- ...

  9. css单标签,单标签!纯CSS实现动态晴阴雨雪

    封面.jpg 1 引言 本期分享一下如何仅用CSS3,实现单标签的动态晴阴雨雪.技术关键点就是"单标签"和"纯CSS".先看下最终效果: 效果预览.gif 再看 ...

最新文章

  1. 微软称不放弃收购雅虎
  2. 信息系统项目管理师-论文专题(四)进度管理论文写作
  3. 大家心目中的这些「优质」论文,你读过几篇?| PaperDaily #01
  4. 如何处理JavaScript中的事件处理(示例和全部)
  5. 深入研究memcache 特性和限制
  6. Android Bitmaps缓存
  7. mysql 执行查询_MySQL执行一个查询的过程
  8. ESP8266开发之旅 网络篇⑯ 无线更新——OTA固件更新
  9. ipv4v6双栈技术_什么是IPv6双栈技术
  10. [重庆思庄每日技术分享]-数据库创建组件时报错ORA-30554: XDB.XDB$ACL_XIDX is disabled
  11. BouncyCastle使用注意事项
  12. Vue项目首页-热销推荐组件开发(7-6)
  13. 两种图像拼接(无重叠相邻图有重叠相邻图)以及matlab实现(边线查找法)
  14. 网站点击热图(Heat Map)
  15. oracle smon 执行记录,Oracle SMON进程中系统监视进程SMON
  16. 图论欧拉回路初步 BZOJ2095 POI2010 Bridges
  17. pycharm使用笔记3-自动生成文件注释和函数注释
  18. EMQX 配置的几点体会
  19. HAL库之485+DMA通信(STM32F746)
  20. win10扩展屏无法全屏显示的问题

热门文章

  1. 钉钉内部应用开发-创建应用
  2. 运放技术——电压跟随器
  3. BIM建模助手将于27日亮相“首届建筑科技创新交流展览会”
  4. cocos2dx tolua ++ 使用 常见得错误
  5. 20171119 - 2.01x - Week 4
  6. pmd java规则_4. PMD 使用,编译和自定义规则
  7. 【社区图书馆】疯狂 Java 讲义:但凡种种,不一而足
  8. Wi-Fi无线网络(WPA2加密)快速破解 ——某公司无线设备安全隐患报告
  9. 华为Mate40、华为Mate40 Pro、华为Mate40 Pro+华为Mate40 RS 的区别
  10. Android - RxEasyHttp网络库请求数据