logo 范 · 拾光录
网址收集 关于作者 Github Gitee
杂文随笔5
Hexo博客:基础使用Hexo博客:Next主题Hexo博客:Next进阶使用Hexo博客:Next高级配置基于Node的WIKI管理
前端知识16
HTML常用知识CSS常用知识CSS美化checkbox复选框JavaScript常用知识JavaScript格式化时间戳JavaScript窗口宽高处理JavaScript黑夜主题切换实现方案JavaScript数字转大写简易图片查看器TypeScript基础知识Threejs基础三要素Threejs网格辅助和轨道控制器Threejs物体绘制Electron基础使用Nodejs基础知识animate.css页面动画
Vue框架19
Vite的使用及扩展Vue3父子组件Vue3使用Marked解析MarkdownMermaid图表生成库初始化页面加载动画Axios表单提交二维码解决方案NProgress加载进度条Vue3动态菜单实现Vue3使用ECharts图表Vue3处理Excel导入导出keep-alive页面缓存及setup问题Element:文件上传Element:结合Pinia实现动态菜单Element:图片上传组件Element:自定义统一弹窗组件Element:表格自定义指令控制按钮显示(鉴权)可视化大屏使用缩放适配分辨率
UniApp15
UniApp的基础使用封装网络请求工具及文件上传uni-app的开发记录微信小程序分享原生文件上传Pinia取消滚动条(兼容小程序)tabbar消息数量显示scroll-view上滑到底部加载数据状态栏高度动态设配数据共享与传递uview-plus导航栏实现背景融合Wot UIWot UI实现顶部背景图融合uni-app x
Java基础知识10
基础知识面向对象Lambda表达式常用API常用知识积累try-with-resource注解反射多线程经纬度距离计算
SpringBoot31
application配置Maven创建聚合项目全局异常处理锁机制项目启动初始化数据方式邮件功能集成原生定时任务异步集成阿里云OSS阿里OSS预签名上传基于hutool读excelJSR303WebSocketWebSocket版AI接口流式调用Smart-Doc接口文档生成器application配置信息加密雪花算法工具AOP实现请求参数脱敏思路JWT生成Token及工具类SpringBoot默认JSON与对象转换若依框架:安装使用若依框架:优化和调整文件上传若依框架:管理后台页面优化若依框架:后端接口代码优化SpringAISpringBoot实现AI接口流式调用服务启动时创建MySQL连接自建项目工程树形结构处理工具微信支付代码微信手机号登录
SpringMVC14
跨域处理拦截器RESTful风格伪前后端分离Jackson转换器调整Thymeleaf基于拦截器做权限校验AOP打印接口请求响应日志AOP打印接口请求响应耗时文件上传和回显POST请求加解密实现(AES)POST请求加解密实现(RSA+AES)参数动态校验实现方案真实IP和归属地
MyBatis8
MyBatis基本使用与配置Mapper使用相关MaBatis多数据源配置MyBatisPlus数据统计类处理方案MyBatisPlus条件查询正向工程的实现(H2)mybatis-plus-join
SpringCloud15
Netflix:微服务与搭建Netflix:服务的消费与提供Netflix:EurekaNetflix:ActuatorNetflix:RibbonNetflix:FeignNetflix:HystrixNetflix:ZuulAlibaba:简介与搭建Alibaba:Nacos注册中心Alibaba:RibbonAlibaba:OpenFeignAlibaba:Nacos配置中心Alibaba:GetewayAlibaba:Sentinel
MySQL6
MySQL基础知识MySQL多表查询与事务MySQL常用函数及解决方案MySQL视图MySQL索引安装MySQL
Redis7
Redis介绍和安装Redis配置文件Redis持久化Redis集群Redis语法基础Redis相关问题及解决方案SpringBoot集成Redis使用记录
MongoDB10
Linux安装MongoDBMongoDB基础语法MongoTemplate及SpringBoot配置MongoTemplate中Update操作MongoTemplate中聚合查询MongoTemplate日期归档示例项目使用相关知识归纳地理位置存储与距离查询MongoDB副本集与事务获取类名和属性名工具类
其他数据库1
H2数据库
Python编程6
Python基础知识Python语法yolo目标检测OpenCV的使用及树莓派平台condauv
工具集合13
IDEAMavenGradleGitNginx安装Nginx配置VSCodeJMeter压测DockerOllamaRustFSPicGoObs录制
Linux知识11
Linux常用命令Jar启动脚本VirtualBox安装CentOSVirtualBox安装Ubuntu树莓派安装及使用frp内网穿透ArchLinux:基础系统安装ArchLInux:图形化界面安装ArchLinux:常用软件ArchLinux:深度优化ArchLinux:Niri
创意设计2
Blender:入门知识UI设计基础知识
AI相关9
Claude CodeHermes AgentOpenAI基本使用OpenAI工具调用OpenAI记忆管理OpenAI推理执行OpenAI开发框架Langchainllama.cpp

在前端项目中,图表的生成算是基本功,使用的场景非常容易出现,所以相应的还是要掌握几种图表制作组件,ECharts是一款基于JavaScript的数据可视化图表库,提供直观,生动,可交互,可个性化定制的数据可视化图表

官网

https://echarts.apache.org/zh/index.html

安装使用

# 安装
npm i echarts
yarn add echarts

# 组件使用时引入
import * as echarts from 'echarts'

使用方式

// 放在DOM加载完成后
onMounted(() => {
  // 解决路由跳转不显示问题
  echarts.dispose(document.getElementById('main1'))
  // 基于准备好的dom,初始化echarts实例
  let myChart = echarts.init(document.getElementById('main1'));

  // 绘制图表
  myChart.setOption({
    title: {
      text: '报告来源'
    },
    tooltip: {},
    xAxis: {
      data: ['国家\n\n机关', '村居\n\n两委', '教育类\n\n从业者', '医疗类\n\n从业者', '旅馆类\n\n从业者', '其他行\n\n业从业者'],
    },
    yAxis: [{
      type: 'value',
      //去掉背景区域
      splitArea: {
        show: false
      },
      // 去除背景线
      splitLine: {
        show: false
      },
      axisLine: { //设置y轴坐标线的样式
        lineStyle: {
          type: 'solid',
          color: '#b8c2c1', //y轴坐标线的颜色
          width: '1' //y轴坐标线的宽度
        }
      },
    }],
    series: [
      {
        name: '销量',
        type: 'bar',
        data: [5, 20, 36, 10, 10, 20]
      }
    ]
  });
})

自定义颜色

series: [
  {
    type: 'pie',
    radius: ['40%', '70%'],
    itemStyle: {
      borderRadius: 2,
      borderWidth: 4,
    },
    labelLine: {
      show: false,
    },
    data: [
      { value: 1048, name: '男生' },
      { value: 735, name: '女生' },
    ],
    // 自定义颜色
    color: ['#1E90FF', '#FF69B4']
  }
]

取消x轴刻度显示

xAxis: {
  type: 'category',
  data: ['06/06', '06/07', '06/08', '06/09', '06/10', '06/11', '06/12'],
  axisTick: {
    show: false, // 取消刻度
  },
  axisLine: {
    lineStyle: {
      type: 'solid',
      color: '#b8c2c1',
      width: '1',
    },
  },
},

label显示

label: {
  show: true,
  position: 'top',
  color: '#9EC4ED',
  fontSize: 12,
  rotate: '90', // 旋转
  offset: [10, 6], // 位置
},

区域面积渐变

series: [
  {
    data: [150, 230, 224, 218, 135, 147, 260],
    type: 'line',
    color: ['#1E90FF'],
    areaStyle: {
      color: {
        type: 'linear',
        x: 0,
        y: 0,
        x2: 0,
        y2: 1,
        colorStops: [
          {
            offset: 0,
            color: 'rgba(58,132,255, 0.5)', // 0% 处的颜色
          },
          {
            offset: 1,
            color: 'rgba(58,132,255, 0)', // 100% 处的颜色
          },
        ],
        global: false, // 缺省为 false
      },
    },
  },
],

图表边距调整

option:{
  grid: {
    left: '36px',
    right: '0%',
    top: '0px',
    bottom: '0px',
  },
}

数据处理(map)

// 数据结构
[
    {
        "data": "2023-10-08",
        "count": 0
    },
    {
        "data": "2023-10-09",
        "count": 0
    },
    {
        "data": "2023-10-10",
        "count": 0
    },
    {
        "data": "2023-10-11",
        "count": 7
    },
    {
        "data": "2023-10-12",
        "count": 4
    }
]

// 数据处理
const echartsX = list.map(function (item) {
  return item.data
})
const echartsY = list.map(function (item) {
  return item.count
})

支持网络请求会刷新

<template>
  <div>
    <div>大门</div>
    <div id="demoShow" style="width: 600px; height: 400px"></div>
  </div>
</template>

<script setup>
import { ref, reactive, onMounted } from 'vue'
import * as echarts from 'echarts'

onMounted(() => {
  // 清除旧实例
  echarts.dispose(document.getElementById('demoShow'))
  demoShow.value = echarts.init(document.getElementById('demoShow'))
  demoShowFunction()
})

// 用于再次更新和销毁实例
let demoShow = ref(null)
function demoShowFunction() {
  demoShow.value.setOption({
    tooltip: {},
    xAxis: {
      data: ['平面设计', '文化墙', '活动项目']
    },
    yAxis: [
      {
        type: 'value',
        splitArea: { show: false },
        splitLine: { show: false }
      }
    ],
    series: [
      {
        name: '数量',
        type: 'bar',
        barWidth: 80,
        label: {
          show: true,
          position: 'top',
          color: '#555',
          fontSize: 16
        },
        data: [
          {
            value: 46,
            itemStyle: {
              color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
                { offset: 0, color: '#2378f7' },
                { offset: 1, color: '#83bff6' }
              ]),
              shadowColor: '#91cc75',
              borderType: 'dashed',
              opacity: 0.9,
              borderRadius: 6
            }
          },
          {
            value: 44,
            itemStyle: {
              color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
                { offset: 0, color: '#ff8788' },
                { offset: 1, color: '#ffc9c9' }
              ]),
              shadowColor: '#91cc75',
              borderType: 'dashed',
              opacity: 0.9,
              borderRadius: 6
            }
          },
          {
            value: 43,
            itemStyle: {
              color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [
                { offset: 0, color: '#56b770' },
                { offset: 1, color: '#99d494' }
              ]),
              shadowColor: '#91cc75',
              borderType: 'dashed',
              opacity: 0.9,
              borderRadius: 6
            }
          }
        ]
      }
    ]
  })
}
</script>

<style scoped lang="scss"></style>
官网
安装使用
使用方式
自定义颜色
取消x轴刻度显示
label显示
区域面积渐变
图表边距调整
数据处理(map)
支持网络请求会刷新