当前位置: 首页 > article >正文

3.在Vue 3中使用Echarts实现水球效果

引言

在数据可视化中,水球图(Liquid Fill Chart)是一种常见的图表类型,它通过流动的液体效果来呈现数字变化,使得数据展示更具动感和视觉吸引力。在本教程中,我们将通过在 Vue 3 项目中结合 EchartsEcharts-LiquidFill 插件来实现一个水球效果,并通过输入框实时更新数据。

环境准备
  1. Vue 3 项目:确保你的开发环境中已经配置好了 Vue 3 项目。如果还没有,你可以使用 Vue CLI 或 Vite 来快速创建一个项目。
  2. Echarts:我们将使用 Echarts 来创建图表,Echarts 是一个非常强大的数据可视化库,支持丰富的图表类型。
  3. Echarts-LiquidFill 插件:该插件扩展了 Echarts 的功能,允许我们创建流体填充效果的水球图。

步骤一:安装依赖

首先,确保你已经安装了 EchartsEcharts-LiquidFill 插件。

npm install echarts echarts-liquidfill --save

步骤二:创建组件并引入 Echarts

在 Vue 3 中,我们通过 <script setup> 来创建组件。首先,我们需要在组件中引入 echartsecharts-liquidfill 插件,并初始化图表。

步骤三:初始化 Echarts 图表

我们在 onMounted 钩子中初始化 Echarts 图表,并使用 updateChart 函数来设置水球图的配置项。

步骤四:设计界面

接下来,我们设计一个简单的界面,其中包括一个输入框,用于动态更新水球的数值,输入框的值会实时反映在水球图上。

这里我们使用了 element-plus 库中的 el-input 组件,绑定了 Data.score 数据,并且通过 @input 事件来更新图表内容。

步骤五:样式设计

通过简单的 CSS 样式让界面看起来更整洁,确保水球效果图居中显示,并且界面响应式良好。

步骤六:结果展示

现在,当你打开这个页面时,你将看到一个水球图,它会根据输入框中输入的数值进行更新。比如,当输入框中的数字为 50 时,水球图的水位会填充到 50%;当数值变为 80 时,水位上升至 80%。

完整代码

<!--
 * @Author: 彭麒
 * @Date: 2024/12/24
 * @Email: 1062470959@qq.com
 * @Description: 此源码版权归吉檀迦俐所有,可供学习和借鉴或商用。
 -->
<template>
  <button class="back-button" @click="goBack">返回</button>
  <div class="font-bold text-[24px]">在Vue3中使用Echarts实现水球效果</div>
  <div class="con">
    <div id="myEcharts" class="w-[180px] h-[180px]"></div>
    <el-input type="number" v-model="Data.score" @input="updateChart" style="width: 240px"/>
  </div>
</template>

<script setup lang="ts">
import { onMounted, onUnmounted, ref } from "vue";
import router from "@/router";
import * as echarts from 'echarts';
import 'echarts-liquidfill';
type EChartsOption = echarts.EChartsOption;
let myChart: echarts.ECharts | null = null;
const Data = ref({
  score: 50
});
const goBack = () => {
  router.push('/Echarts')
}
const initChart = () => {
  const chartDom = document.getElementById('myEcharts') as HTMLElement;
  if (chartDom) {
    myChart = echarts.init(chartDom, 'default');
    updateChart();
    window.onresize = () => {
      myChart?.resize();
    };
  } else {
    console.error('Chart DOM element not found');
  }
};

const updateChart = () => {
  if (myChart) {
    const score = Data.value.score || 0;
    const option: EChartsOption = {
      title: [{
        bottom: '15%',
        left: 'center',
        textStyle: {
          color: '#4F515A',
          fontSize: 16,
          fontWeight: 300
        }
      }],
      series: [{
        type: 'liquidFill',
        radius: '60%',
        color: [
          '#def2fe',
          '#b6e3fc',
          new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
            offset: 0,
            color: "#72D1FB",
          }, {
            offset: 0.8,
            color: "#43ABF7",
          }])
        ],
        data: [score / 100, score / 100, score / 100],
        center: ['50%', '50%'],
        label: {
          normal: {
            formatter: String(score),
            fontSize: 30,
            fontWeight: 400,
            color: '#72D1FB'
          }
        },
        itemStyle: {
          shadowBlur: 0
        },
        emphasis: {
          itemStyle: {
            opacity: 0.8,
          },
        },
        outline: {
          borderDistance: 0,
          itemStyle: {
            borderWidth: 4,
            borderColor: '#ecebea',
            shadowBlur: 20
          }
        },
        backgroundStyle: {
          color: '#fff'
        }
      }]
    };
    myChart.setOption(option);
  }
};

onMounted(() => {
  initChart();
});

onUnmounted(() => {
  if (myChart) {
    myChart.dispose();
  }
});
</script>

<style scoped lang="scss">
.con {
  width: 100%;
  height: 100%;
  display: flex;
  justify-content: center;
  align-items: center;
  flex-direction: column;
}
</style>

小结

在这篇文章中,我们展示了如何在 Vue 3 项目中使用 Echarts 实现一个简单的水球效果,并通过输入框实现实时更新。你可以将此效果应用于各种实时监控、数据展示或动态仪表盘的项目中。希望你能从中获得灵感,并将其应用到自己的项目中。


http://www.kler.cn/a/458522.html

相关文章:

  • 八大排序——直接插入排序
  • Java 8 及经典面试题全解析
  • 2021年国家公考《申论》题(地市级)
  • 【蓝桥杯——物联网设计与开发】拓展模块4 - 脉冲模块
  • 基于服务器部署的综合视频安防系统的智慧快消开源了。
  • 自学记录:鸿蒙5使用ArkTS和ArkUI实现Live View功能
  • linux安装nginxs报错:openssl not found
  • 20241227在ubuntu20.04.6系统中,如何用watch命令每秒钟调用nvidia-smi来监控GPU
  • 【Spring】基于XML的Spring容器配置——Bean的作用域
  • Web开发:ORM框架之使用Freesql的分表分页写法
  • Android 设置铃声和闹钟
  • Docker--Kibana
  • MYSQL如何重置root密码
  • MYSQL使用角色
  • wx006基于springboot+vue+uniapp的电器维修系统小程序
  • uniapp下载打开实现方案,支持安卓ios和h5,下载文件到指定目录,安卓文件管理内可查看到
  • termux-boot安卓开机自动启动应用
  • Colyseus的room.onStateChange重复触发问题
  • Redis 集群架构:高可用与扩展性
  • 苍穹外卖day07缓存部分分析
  • 深入理解 Docker 网桥配置与网络管理
  • C#编写的金鱼趣味小应用 - 开源研究系列文章
  • 博通收购VMware后,新旧VMware兼容性列表查询方案对比
  • 未来网络技术的新征程:5G、物联网与边缘计算(10/10)
  • 【小程序】wxss与rpx单位以及全局样式和局部样式
  • PG备份恢复--pg_dump