北忆

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
统计
 

 

1,有关echarts引用的相关报错直接写这句  import * as echarts from 'echarts'

2,折线图

 

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
chartsObj = {
    tooltip: {
      trigger: 'axis',
      axisPointer: {
        type:'none', // 默认为line,不关闭会有引线跟随
      },
      formatter(params:any) { //自定义提示框,可打印params查看
        let str = ''
        params.forEach((item:any)=>{
                str += `<span style="font-size: 14px;">${item.name}</span>
            <div style="margin-top: 20px;display:flex;align-items:center;">
              <div style="display: inline-block;width: 7px;border-radius: 50%;height:7px;background: #FF8543;"></div>
              <span style="padding-left: 8px">资产数:<span style="font-weight: 600">${item.value}</span></span>
            </div>`
            })
        return (str);
      },
    },
    grid: {
      top: '5%',
      left: '1%',
      right: '2.5%',
      bottom: '5%',
      containLabel: true // 区域自适应
    },
    xAxis: {
      type: 'category',
      axisTick: { // 是否显示刻度线
        show: false
      },   
      boundaryGap: false, // 不留白,从原点开始
      axisLine: { //横坐标横线线条
        lineStyle: {
          type: 'solid',
          color: '#ccc',
        }
      },
      axisLabel: { // 横坐标字体
        textStyle: {
          color: '#4D5059 '
        }
      },
      splitLine: { // 横坐标上方线条显示及颜色
        show:true,
        lineStyle : {
          color: '#cccc',
          type: 'dashed'
        }
      }
    },
    yAxis: {
      type: 'value',
      axisTick: {
        show: false
      },
      axisLine: {
        show:true,
        lineStyle: {
          type: 'solid',
          color: '#ccc',
        }
      },
      axisLabel: { // y轴文字设置
        textStyle: {
          color: '#4D5059 '
        },
        lineStyle: {
          color: '#F2F4F7',
        }
      },
      splitLine: {
        lineStyle : {
          color: '#cccc',
          type: 'dashed'
        }
      }
    },
    series: [
      {
        data: [],
        type: 'line',
        symbol:'circle',
        smooth:true,
        symbolSize:10,//拐点大小
        itemStyle: {
          normal: {
            color: '#FF8543', //改变折线点的颜色
            lineStyle: {
              color: '#FF8543' //改变折线颜色
            }
          }
              },
        areaStyle: { // 区域渐变色
          normal: {
            color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [{
                  offset: .2,
                  color: 'rgba(255,133,67,0.16)'
              }, {
                  offset: .8,
                  color: 'rgba(66, 133, 244, 0)'
              }])
          }
        },
        showSymbol: false, // 是否展示折线上的圆点默认
      }
    ]
  }

 3,饼图 

 

 

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
chartsObj ={
    title: {
      textStyle: {
        fontFamily: 'PingFangSC-Medium, sans-serif',
        fontWeight: 500,
        fontSize: 14
      },
      bottom: '15%',
      left: '40%'
    },
    legend: {
        right:10,
        top:10,
        orient : 'vertical',
        icon: "circle",
        type: "scroll", // 是否开启切换图例分页
        itemWidth: 12, // 图例标记的图形宽度。
        itemHeight: 12, //  图例标记的图形高度。
        width: 'auto', // 图例组件的宽度
        height: 'auto', // 图例组件的高度
    },
    tooltip: {
     // trigger: 'item',
      formatter(item:any) {
        let str = ''
        str += `<span style="font-size: 14px;color:${item.color};">${item.name}</span>
          <div style="margin-top: 5px;display:flex;align-items:center;">
            <div style="display: inline-block;width: 7px;border-radius: 50%;height:7px;background: ${item.color};"></div>
            <span style="padding-left: 8px";>数量:<span style="font-weight: 600">${item.value}</span></span>
          </div>`
        return str;
      }
    },
    series: [
      {
        type: 'pie',
        bottom: '20%',
        radius: ['60%', '90%'],
        avoidLabelOverlap: false,
        label: {
          normal: {
              show: false,
          },
        },
        data: [],
        color:['#F5222D', '#FF8543', '#FFBB00', '#4285F4']
      }
    ]
  }

4,一般各种图标要自适应缩放,所以添加监听事件

      window.addEventListener('resize',this.handleWindowResize)
 
5 ,当组件离开要在销毁生命周期中释放掉以及清空监听事件
    this.myChartDate.dispose()
    window.removeEventListener('resize',this.handleWindowResize)
 
6,其他补充
 1.饼图title,不要使用百分比;top和bottom可以,尤其是left和right最好别用,会有下图问题;可用x,y属性控制
    title: {
     x:'center',
      bottom:'15%',
    }

 2,折线图y轴线条真的是无语了,想要加颜色必须加上show:true;x轴就不用加;

     axisLine: {
        show:true,
        lineStyle: {
          type: 'solid',
          color: '#E7EFFD',
        }
      },
 
3,自定义划图案,一共三种;官方提供的symbol:‘支持的属性’;还有两种svg和base64
svg适合单个图案,因为要用到path。多个path无法支持。
base64 适合png图片,ui可以自定义。如下,base64方案,在symbol设置,前提是(  image://  )要和base64的路径拼接上,否则不出来。
1
2
3
4
5
6
7
8
9
10
series: [
      {
        data: [],
        type: 'line',
        symbol:'image://',
        smooth:true,
        symbolSize:20,//拐点大小
      }
 
]

  

 

posted on   北忆  阅读(144)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
 
点击右上角即可分享
微信分享提示