echarts图表格式记录

单柱图/单条形图

chartData: {
    axisData: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'],
    seriesData: [120, 200, 150, 80, 70, 110, 130]
}

单柱图+标线

chartData: {
    axisData: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'],
    seriesData: [120, 200, 150, 80, 70, 110, 130],
    // 标线数据
    markData: [
        { address: '省', value: 125 },
        { address: '市', value: 100 },
        { address: '县', value: 80 }
    ]
}

在这里插入图片描述

多柱图/多条形图

chartData: {
    axisData: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'],
    seriesData: [
        {
            name: '指标1',
            dataList: [120, 130, 234, 245, 2444, 123]
        },
        {
            name: '指标2',
            dataList: [120, 130, 234, 245, 2444, 123]
        },
        {
            name: '指标3',
            dataList: [120, 130, 234, 245, 2444, 123]
        },
        {
            name: '指标4',
            dataList: [120, 130, 234, 245, 2444, 123]
        }
    ]
}

在这里插入图片描述

堆叠柱状图/堆砌柱状图

注意:x轴上数据为正,x轴下数据为负

chartData: {
    axisData: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'],
    seriesData: [
        {
            name: '指标1',
            dataList: [120, 130, 234, 245, 2444, 123]
        },
        {
            name: '指标2',
            dataList: [120, 130, 234, 245, 2444, 123]
        },
        {
            name: '指标3',
            dataList: [120, 130, 234, 245, 2444, 123]
        },
        {
            name: '指标4',
            dataList: [120, 130, 234, 245, 2444, 123]
        }
    ]
}

在这里插入图片描述

折线图(单线图)

chartData: {
    axisData: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat', 'Sun'],
    seriesData: [120, 200, 150, 80, 70, 110, 130]
}

多折线图

chartData: {
    axisData: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat'],
    seriesData: [
        {
            name: '指标1',
            dataList: [123, 131, 224, 123, 567, 342]
        },
        {
            name: '指标2',
            dataList: [234, 145, 234, 245, 232, 123]
        },
        {
            name: '指标3',
            dataList: [12, 231, 234, 245, 244, 123]
        },
        {
            name: '指标4',
            dataList: [43, 456, 234, 245, 250, 123]
        }
    ]
}

在这里插入图片描述

单柱+单折

注意:需要明确那部分数据是柱状图展示所需数据,哪些数据是折线图的数据

chartData: {
    axisData: ['Mon', 'Tue', 'Wed', 'Thu', 'Fri', 'Sat']
    seriesLineData: {
        name: '指标1',
        value: [120, 130, 234, 245, 2444, 123]
    },
    seriesBarData: {
        name: '指标2',
        value: [150, 230, 224, 218, 135, 147]
    }
}

单柱+单折显示上升下降趋势

var up = 'image://'
var down = 'image://'
var same = 'image://'

var chartData = {
  axisData: ['第一季度', '第二季度', '第三季度', '第四季度'],
  seriesBarData: {
    name: '有形资产净增率',
    dataList: [242.97, 234.31, 239.065, 236.27]
  },
  seriesLineData: {
    name: '有形资产净增率',
    dataList: [2.83, -3.56, 0.65, -2.49]
  }
}
option = {
  xAxis: {
    type: 'category',
    data: chartData.axisData
  },
  yAxis: {
      type: 'value',
    },
  tooltip: {
    formatter: (params) => {
      console.log(params)
      return '数值:' + chartData.seriesBarData.dataList[params.dataIndex] + 
      '\n增幅:' + chartData.seriesLineData.dataList[params.dataIndex]
    }
  },
  series: [
    {
      name: '',
      type: 'pictorialBar',
      symbol: function (data, params) {
        if (chartData.seriesLineData.dataList[params.dataIndex] > 0) {
          return up
        } else if (chartData.seriesLineData.dataList[params.dataIndex] < 0) {
          return down
        } else if (chartData.seriesLineData.dataList[params.dataIndex] == 0) {
          return same
        }
      },
      symbolSize: [20, 30],
      symbolOffset: [0, -40],
      symbolPosition: 'end',
      label: {
        show: true,
        position: 'top',
        formatter: function (params) {
          return chartData.seriesLineData.dataList[params.dataIndex] + '%'
        },
        fontSize: 18
      },
      data: chartData.seriesBarData.dataList
    },
    {
      type: 'bar',
      data: chartData.seriesBarData.dataList,
      barWidth: this.barWidth
    }
  ]
};

单饼图/单环图

chartData: [
    { value: 1048, name: 'Search Engine' },
    { value: 735, name: 'Direct' },
    { value: 580, name: 'Email' },
    { value: 484, name: 'Union Ads' },
    { value: 300, name: 'Video Ads' }
]

双环图

chartData: [
    {
        name: '税额',
        seriesData: [
            { value: 1048, name: '开发区分局' },
            { value: 735, name: '金港分局' },
            { value: 580, name: '塘桥分局' },
            { value: 484, name: '保税区' },
            { value: 300, name: '锦丰分局' },
            { value: 580, name: '凤凰分局' },
            { value: 484, name: '乐余分局' },
            { value: 300, name: '大新分局' }
        ]
    },
    {
        name: '人数',
        seriesData: [
            { value: 40, name: '开发区分局' },
            { value: 38, name: '金港分局' },
            { value: 32, name: '塘桥分局' },
            { value: 30, name: '保税区' },
            { value: 28, name: '锦丰分局' },
            { value: 26, name: '凤凰分局' },
            { value: 22, name: '乐余分局' },
            { value: 18, name: '大新分局' }
        ]
    }
]

在这里插入图片描述

单柱变动图/单条变动图

传参1

var chartData = {
	timeLindata: ['2018', '2019', '2020', '2021'],
	seriesData: [
		{
			xdata: ['批发零售', '制造业', '商务服务', '居民服务'],
			ydata: [3,4,5,6]
		}, // 2018
		{
			xdata: ['批发零售', '制造业', '商务服务', '居民服务'],
			ydata: [13,24,15,26]
		}, // 2019
		{
			xdata: ['批发零售', '制造业', '商务服务', '居民服务'],
			ydata: [3,4,5,6]
		}, // 2020
		{
			xdata: ['批发零售', '制造业', '商务服务', '居民服务'],
			ydata: [33,24,35,56]
		} // 2021
	]
}
var optionVal = chartData.seriesData.map((item, index) => {
  return {
    title: {
      text: chartData.timeLindata[index] + '年'
    },
    xAxis: {
      data: item.xdata
    },
    series: {
      type: 'bar',
      data: item.ydata
    }
  }
  
})
option = {
  baseOption: {
    timeline: {
      data: chartData.timeLindata,
      axisType: 'category',
      autoPlay: true,
      playInterval: 1500,
    },
    title: {
      text: '',
      right: '2%',
      bottom: '8%',
      textStyle: {
        fontSize: 50,
        color: '#000'
      }
    },
    xAxis: {
      type: 'category'
    },
    yAxis: {
      type: 'value'
    }
  },
  options: optionVal
}

传参2

var chartData = {
	timelineData: ['2016', '2017', '2018', '2019'],
  xData: ['批发零售', '制造业', '商务服务', '居民服务', '建筑业', '住宿餐饮', '科研'],
  yData: [
      [13.2, 1.11, 13.6, 9284, 64138, 2237, 4779], // 2016
      [15.26, 1.31, 16.68, 10331, 91580, 1909, 40469], // 2017
      [14.23, 1.31, 21.13, 10873, 94964, 2966, 129748], // 2018
      [15.68, 1.56, 34.55, 10289, 92345, 1099, 132011] // 2019
   ]
}
var optionVal = chartData.yData.map((item, index) => {
  return {
    title: {
      text: chartData.timelineData[index] + '年'
    },
    xAxis: {
      data: chartData.xData
    },
    series: {
      type: 'bar',
      data: item
    }
  }
})
option = {
  baseOption: {
    timeline: {
      data: chartData.timelineData,
      axisType: 'category',
      autoPlay: true,
      playInterval: 1500,
    },
    title: {
      text: '',
      right: '2%',
      bottom: '8%',
      textStyle: {
        fontSize: 50,
        color: '#000'
      }
    },
    tooltip: {
      trigger: 'axis'
    },
    xAxis: {
      type: 'category'
    },
    yAxis: {
      type: 'value'
    }
  },
  options: optionVal
}

在这里插入图片描述

单柱变动图显示上升下降趋势

var up='image://'    
var down = 'image://'
var same = 'image://'

var chartData = {
	timelineData: ['2018', '2019', '2020', '2021'], // 变量名修改
	seriesData: [
		{
			xdata: ['批发零售', '制造业', '商务服务', '居民服务'],
			ydata: [3,4,5,6],
			status: [up, up, down, down]
		}, // 2018
		{
			xdata: ['批发零售', '制造业', '商务服务', '居民服务'],
			ydata: [13,24,15,26],
			status: [down, up, up, down]
		}, // 2019
		{
			xdata: ['批发零售', '制造业', '商务服务', '居民服务'],
			ydata: [3,4,5,6],
			status: [up, down, up, down]
		}, // 2020
		{
			xdata: ['批发零售', '制造业', '商务服务', '居民服务'],
			ydata: [33,24,35,56],
			status: [up, down, down, up]
		} // 2021
	]
}
var optionVal = chartData.seriesData.map((item, index) => {
  return {
    // title: {
    //   text: this.chartData.timelineData[index] + '年'
    // },
    xAxis: {
      data: item.xdata
    },
    tooltip: {},
    series: [
      {
        name: "",
        type: 'pictorialBar',
        symbol: function(data,params){
            return item.status[params.dataIndex]
        },
        symbolSize: [20, 30],
        symbolOffset: [0, -40],
        color:'orange',
        symbolPosition: 'end',
        label: {
            show: true,
            position: "top",
            formatter:  function(params){
                return item.ydata[params.dataIndex]
            },
            fontSize: 30,
            fontWeight: 'bold',
            color: '#34DCFF'
        },
        data: item.ydata
      },
      {
        type: 'bar',
        data: item.ydata,
        barWidth: 60
      }
    ]
  }
})
option = {
  baseOption: {
    timeline: {
      data: chartData.timelineData,
      axisType: 'category',
      autoPlay: true,
      playInterval: 1500,
    },
    title: {
      text: '',
      right: '2%',
      bottom: '8%',
      textStyle: {
        fontSize: 50,
        color: '#000'
      }
    },
    xAxis: {
      type: 'category'
    },
    yAxis: {
      type: 'value'
    }
  },
  options: optionVal
}

单饼图变动图

var json = {
    // 变量名修改
	timelineData: ['2018', '2019', '2020', '2021'],
	seriesData: [
		{
			name: '2018',
			value: [
				{ value: 1048, name: 'Search Engine' },
				{ value: 735, name: 'Direct' },
				{ value: 580, name: 'Email' },
				{ value: 484, name: 'Union Ads' },
				{ value: 300, name: 'Video Ads' }
			]
		},
		{
			name: '2019',
			value: [
				{ value: 10, name: 'Search Engine' },
				{ value: 20, name: 'Direct' },
				{ value: 30, name: 'Email' },
				{ value: 40, name: 'Union Ads' },
				{ value: 50, name: 'Video Ads' }
			]
		},
		{
			name: '2020',
			value: [
				{ value: 1048, name: 'Search Engine' },
				{ value: 735, name: 'Direct' },
				{ value: 580, name: 'Email' },
				{ value: 484, name: 'Union Ads' },
				{ value: 300, name: 'Video Ads' }
			]
		},
		{
			name: '2021',
			value: [
				{ value: 1048, name: 'Search Engine' },
				{ value: 735, name: 'Direct' },
				{ value: 580, name: 'Email' },
				{ value: 484, name: 'Union Ads' },
				{ value: 300, name: 'Video Ads' }
			]
		}
	]
}

在这里插入图片描述

单折线变动图

json = {
	timelineData: ['2018', '2019', '2020', '2021'] // 变量名修改
	data: [
		{
			xdata: ['批发零售', '制造业', '商务服务', '居民服务'],
			ydata: [3,4,5,6]
		}, // 2018
		{
			xdata: ['批发零售', '制造业', '商务服务', '居民服务'],
			ydata: [3,4,5,6]
		}, // 2019
		{
			xdata: ['批发零售', '制造业', '商务服务', '居民服务'],
			ydata: [3,4,5,6]
		}, // 2020
		{
			xdata: ['批发零售', '制造业', '商务服务', '居民服务'],
			ydata: [3,4,5,6]
		} // 2021
	]
}

多柱变动图/多条变动图

// 数据类型
var chartData = {
	timelineData: ['2018', '2019', '2020', '2021'], // 变量名修改
	seriesData: [
		{
			xdata: ['批发零售', '制造业', '商务服务', '居民服务'],
			ydata: [
                {
                    name: '指标1',
                    dataList: [3,4,5,6]
                },
                {
                    name: '指标2',
                    dataList: [3,4,5,6]
                },
            ]
		}, // 2018
		{
			xdata: ['批发零售', '制造业', '商务服务', '居民服务'],
			ydata: [
                {
                    name: '指标1',
                    dataList: [33,24,35,56]
                },
                {
                    name: '指标2',
                    dataList: [3,4,5,6]
                },
            ]
		}, // 2019
		{
			xdata: ['批发零售', '制造业', '商务服务', '居民服务'],
			ydata: [
                {
                    name: '指标1',
                    dataList: [33,24,35,56]
                },
                {
                    name: '指标2',
                    dataList: [3,4,5,6]
                },
            ]
		}, // 2020
		{
			xdata: ['批发零售', '制造业', '商务服务', '居民服务'],
			ydata: [
                {
                    name: '指标1',
                    dataList: [33,24,35,56]
                },
                {
                    name: '指标2',
                    dataList: [3,4,5,6]
                },
            ]
		} // 2021
	]
}


var optionVal = chartData.seriesData.map((item, index) => {
    return {
		xAxis: item.xdata,
		series: item.ydata.map((item1, index1) => {
			return {
				name: item1.name,
				type: 'bar',
				data: item1.dataList
			}
		})
	}
})
option = {
  baseOption: {
    timeline: {
      data: chartData.timelineData,
      axisType: 'category',
      autoPlay: true,
      playInterval: 1500,
    },
    title: {
      text: '',
      right: '2%',
      bottom: '8%',
      textStyle: {
        fontSize: 50,
        color: '#000'
      }
    },
    xAxis: {
      type: 'category'
    },
    yAxis: {
      type: 'value'
    }
  },
  options: optionVal
}

在这里插入图片描述

多折线变动图

// 数据类型
var chartData = {
	timelineData: ['2018', '2019', '2020', '2021'], // 变量名修改
	seriesData: [
		{
			xdata: ['批发零售', '制造业', '商务服务', '居民服务'],
			ydata: [
                {
                    name: '指标1',
                    dataList: [3,4,5,6]
                },
                {
                    name: '指标2',
                    dataList: [3,4,5,6]
                },
            ]
		}, // 2018
		{
			xdata: ['批发零售', '制造业', '商务服务', '居民服务'],
			ydata: [
                {
                    name: '指标1',
                    dataList: [33,24,35,56]
                },
                {
                    name: '指标2',
                    dataList: [3,4,5,6]
                },
            ]
		}, // 2019
		{
			xdata: ['批发零售', '制造业', '商务服务', '居民服务'],
			ydata: [
                {
                    name: '指标1',
                    dataList: [33,24,35,56]
                },
                {
                    name: '指标2',
                    dataList: [3,4,5,6]
                },
            ]
		}, // 2020
		{
			xdata: ['批发零售', '制造业', '商务服务', '居民服务'],
			ydata: [
                {
                    name: '指标1',
                    dataList: [33,24,35,56]
                },
                {
                    name: '指标2',
                    dataList: [3,4,5,6]
                },
            ]
		} // 2021
	]
}


var optionVal = chartData.seriesData.map((item, index) => {
    return {
		xAxis: item.xdata,
		series: item.ydata.map((item1, index1) => {
			return {
				name: item1.name,
				type: 'line',
				data: item1.dataList
			}
		})
	}
})
option = {
  baseOption: {
    timeline: {
      data: chartData.timeLindata,
      axisType: 'category',
      autoPlay: true,
      playInterval: 1500,
    },
    title: {
      text: '',
      right: '2%',
      bottom: '8%',
      textStyle: {
        fontSize: 50,
        color: '#000'
      }
    },
    xAxis: {
      type: 'category'
    },
    yAxis: {
      type: 'value'
    }
  },
  options: optionVal
}

在这里插入图片描述

双环变动图

var json = {
	timelineData: ['2018', '2019', '2020', '2021'], // 变量名修改
	seriesData: [
		{
			name: '2018',
			value: [
                {
                    name: '指标1',
                    data: [
                        { value: 1048, name: 'Search Engine' },
                        { value: 735, name: 'Direct' },
                        { value: 580, name: 'Email' },
                        { value: 484, name: 'Union Ads' },
                        { value: 300, name: 'Video Ads' }
                    ]
                },
                {
                    name: '指标2',
                    data: [
                        { value: 40, name: 'rose 1' },
                        { value: 38, name: 'rose 2' },
                        { value: 32, name: 'rose 3' },
                        { value: 30, name: 'rose 4' },
                        { value: 28, name: 'rose 5' },
                        { value: 26, name: 'rose 6' },
                        { value: 22, name: 'rose 7' },
                        { value: 18, name: 'rose 8' }
                    ]
                }
            ]
		},
		{
			name: '2019',
			value: [
                {
                    name: '指标1',
                    data: [
                        { value: 1048, name: 'Search Engine' },
                        { value: 735, name: 'Direct' },
                        { value: 580, name: 'Email' },
                        { value: 484, name: 'Union Ads' },
                        { value: 300, name: 'Video Ads' }
                    ]
                },
                {
                    name: '指标2',
                    data: [
                        { value: 40, name: 'rose 1' },
                        { value: 38, name: 'rose 2' },
                        { value: 32, name: 'rose 3' },
                        { value: 30, name: 'rose 4' },
                        { value: 28, name: 'rose 5' },
                        { value: 26, name: 'rose 6' },
                        { value: 22, name: 'rose 7' },
                        { value: 18, name: 'rose 8' }
                    ]
                }
            ]
		},
		{
			name: '2020',
			value: [
                {
                    name: '指标1',
                    data: [
                        { value: 1048, name: 'Search Engine' },
                        { value: 735, name: 'Direct' },
                        { value: 580, name: 'Email' },
                        { value: 484, name: 'Union Ads' },
                        { value: 300, name: 'Video Ads' }
                    ]
                },
                {
                    name: '指标2',
                    data: [
                        { value: 40, name: 'rose 1' },
                        { value: 38, name: 'rose 2' },
                        { value: 32, name: 'rose 3' },
                        { value: 30, name: 'rose 4' },
                        { value: 28, name: 'rose 5' },
                        { value: 26, name: 'rose 6' },
                        { value: 22, name: 'rose 7' },
                        { value: 18, name: 'rose 8' }
                    ]
                }
            ]
		},
		{
			name: '2021',
			value: [
                {
                    name: '指标1',
                    data: [
                        { value: 1048, name: 'Search Engine' },
                        { value: 735, name: 'Direct' },
                        { value: 580, name: 'Email' },
                        { value: 484, name: 'Union Ads' },
                        { value: 300, name: 'Video Ads' }
                    ]
                },
                {
                    name: '指标2',
                    data: [
                        { value: 40, name: 'rose 1' },
                        { value: 38, name: 'rose 2' },
                        { value: 32, name: 'rose 3' },
                        { value: 30, name: 'rose 4' },
                        { value: 28, name: 'rose 5' },
                        { value: 26, name: 'rose 6' },
                        { value: 22, name: 'rose 7' },
                        { value: 18, name: 'rose 8' }
                    ]
                }
            ]
		}
	]
}

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
可以使用ECharts来实现Git提交记录的可视化。具体实现方法如下: 1. 首先,需要将Git提交记录导出为一个JSON文件,可以使用Git的命令行工具或者第三方工具来导出。例如,使用Git的命令行工具可以执行以下命令: ``` git log --pretty=format:'{%n "commit": "%H",%n "author": "%an <%ae>",%n "date": "%ad",%n "message": "%f"%n},' > log.json ``` 该命令将所有提交记录导出为一个JSON文件,并且每个提交记录都是一个JSON对象。 2. 接下来,需要使用ECharts来读取JSON文件,并将提交记录可视化为一个图表。可以使用ECharts的数据格式化功能来将JSON文件解析为ECharts所需的数据格式。例如,可以使用以下代码来读取JSON文件并解析为ECharts所需的数据格式: ``` $.getJSON("log.json", function (data) { var dateList = data.map(function (item) { return item.date; }); var commitList = data.map(function (item) { return item.commit.substring(0, 7); }); var chartData = data.map(function (item, index) { var color = 'lightgreen'; if (index % 2 === 1) { color = 'pink'; } return { value: [index, item.message, item.author, item.commit], itemStyle: { color: color } } }); var option = { tooltip: {}, title: [{ text: 'Git提交记录可视化', left: 'center' }], grid: [{ left: 50, right: 50, bottom: 10, top: 60, containLabel: true }], xAxis: [{ type: 'category', boundaryGap: false, data: dateList, axisLabel: { formatter: function (value) { return echarts.format.formatTime('yyyy-MM-dd', value); } }, splitLine: { show: true, lineStyle: { color: '#999', type: 'dashed' } }, axisLine: { lineStyle: { color: '#999' } } }], yAxis: [{ type: 'category', data: commitList, axisLine: { lineStyle: { color: '#999' } } }], series: [{ type: 'scatter', symbolSize: 20, data: chartData, animationDelay: function (idx) { return idx * 5; } }] }; var chart = echarts.init(document.getElementById('chart')); chart.setOption(option); }); ``` 该代码将JSON文件解析为一个ECharts图表,并且使用散点图来表示提交记录。每个提交记录都是一个散点,可以通过鼠标悬浮来查看提交信息。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值