let barImg = '' let app = new Vue({ el: '#app', data() { return { year: '2022', config1: { number: [100], content: '{nt}个', }, centerData: '', storageRecordConfig: { header: ['项目名称', '投资金额', '所属产业', '项目进度', '完成比例'], headerBGC: '#05507b33', oddRowBGC: '#69c0ff0f', evenRowBGC: '', headerHeight: '40', rowNum: 4, align: ['center'], data: [ ['工程建设项目', '21.2亿', '煤炭', '终止', '2.3%'], ['工程建设项目', '21.2亿', '煤炭', '退出', '2.3%'], ['工程建设项目', '21.2亿', '煤炭', '进行中', '2.3%'], ['工程建设项目', '21.2亿', '煤炭', '进行中', '2.3%'], ['工程建设项目', '21.2亿', '煤炭', '进行中', '2.3%'], ['工程建设项目', '21.2亿', '煤炭', '进行中', '2.3%'], ], }, storageRecordConfig2: { header: ['项目名称', '投资金额', '所属产业', '项目进度', '完成比例'], headerBGC: '#05507b33', oddRowBGC: '#05507b33', evenRowBGC: '', headerHeight: '40', rowNum: 4, align: ['center'], data: [ ['工程建设项目', '21.2亿', '煤炭', '终止', '2.3%'], ['工程建设项目', '21.2亿', '煤炭', '退出', '2.3%'], ['工程建设项目', '21.2亿', '煤炭', '进行中', '2.3%'], ['工程建设项目', '21.2亿', '煤炭', '进行中', '2.3%'], ['工程建设项目', '21.2亿', '煤炭', '进行中', '2.3%'], ['工程建设项目', '21.2亿', '煤炭', '进行中', '2.3%'], ], }, companyList: companyList, commonOption: { title: { text: 'xxx', x: 'center', y: '3%', textStyle: { color: '#69C0FF', fontSize: 24, }, }, tooltip: { trigger: 'axis', axisPointer: { type: 'shadow', }, }, grid: { top: '22%', right: '3%', left: '3%', bottom: '20%', }, legend: { data: '', top: '12%', right: '10', textStyle: { color: 'rgba(250,250,250,0.6)', fontSize: 16, }, }, xAxis: { data: companyList.map(item => item.name), axisLine: { show: true, //隐藏X轴轴线 lineStyle: { color: '#005094', width: 1, }, }, axisTick: { show: false, //隐藏X轴刻度 }, axisLabel: { show: true, rotate: 15, textStyle: { color: 'rgba(255,255,255,0.6)', //X轴文字颜色 fontSize: 16, }, }, }, yAxis: [ { type: 'value', nameTextStyle: { color: '#ebf8ac', fontSize: 16, }, splitLine: { show: true, lineStyle: { color: '#68b4dd66', type: 'dashed', }, }, axisLine: { show: false, }, axisLabel: { show: true, textStyle: { color: 'rgba(250,250,250,0.6)', fontSize: 16, }, }, }, ], }, } }, mounted() { this.centerData = data // 左侧图表 this.initChartL1() this.initChartL2() this.initChartL3() // 中间图标 this.initChartC1() this.initChartC2() // 右侧图表 this.initChartR1() this.initChartR2() this.initChartR3() }, methods: { numFormat(value) { if (!value) return '0' var intPart = Number(value).toFixed(0) // 获取整数部分 var intPartFormat = intPart.toString() .replace(/(\d)(?=(?:\d{3})+$)/g, '$1,') // 将整数部分逢三一断 var floatPart = '.00' // 预定义小数部分 var value2Array = value.toString().split('.') // =2表示数据有小数位 if (value2Array.length === 2) { floatPart = value2Array[1].toString() // 拿到小数部分 if (floatPart.length === 1) { // 补0 return intPartFormat + '.' + floatPart + '0' } else { return intPartFormat + '.' + floatPart } } else { return intPartFormat } }, // 左侧侧图表---------------------------------------------开始 initChartL1() { let myChart = echarts.init(this.$refs['echartL1']) let option = { ...this.commonOption, series: [ { name: '', type: 'bar', barWidth: 10, itemStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [ { offset: 0, color: '#69c0ff', }, { offset: 1, color: '#082550', }, ]), }, }, data: [16, 14, 16, 12, 15, 12, 17], }, { data: [16, 14, 16, 12, 15, 12, 17], type: 'pictorialBar', barMaxWidth: '20', symbolPosition: 'end', symbol: 'image://' + barImg, symbolOffset: ['0', '-25'], symbolSize: [35, 35], zlevel: 2, }, ], } option.title.text = '当前各二级企业本部机构数' myChart.setOption(option) }, initChartL2() { let myChart = echarts.init(this.$refs['echartL2']) let option = { ...this.commonOption, series: [ { name: '人数', type: 'line', yAxisIndex: 1, //使用的 y 轴的 index,在单个图表实例中存在多个 y轴的时候有用 smooth: true, //平滑曲线显示 showAllSymbol: true, //显示所有图形。 symbol: 'circle', //标记的图形为实心圆 symbolSize: 8, //标记的大小 smooth: false, itemStyle: { //折线拐点标志的样式 color: '#69c0ff', borderColor: '#69c0ff', width: 2, shadowColor: '#69c0ff', shadowBlur: 4, }, lineStyle: { color: '#69c0ff', width: 2, }, areaStyle: { //区域填充样式 normal: { color: new echarts.graphic.LinearGradient( 0, 0, 0, 1, [ { offset: 0, color: '#69c0ff', }, { offset: 1, color: 'rgba(0,0,0,0)', }, ], false ), }, }, data: [60, 50, 40, 90, 30, 55, 40, 20, 50, 40, 40, 55, 40, 30, 50, 40, 35, 40], } ], } option.title.text = '当前各二级企业中层管理人员人数' option.legend.data = ['人数'] option.yAxis.push({ splitLine: { show: false, }, axisLine: { show: false, }, }) myChart.setOption(option) }, initChartL3() { let myChart = echarts.init(this.$refs['echartL3']) let option = { ...this.commonOption, series: [ { name: '', type: 'bar', barWidth: 10, itemStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [ { offset: 0, color: '#43ede3', }, { offset: 1, color: '#082550', }, ]), }, }, data: [50, 40, 60, 20, 45, 30, 60, 40, 45, 40, 50, 20, 60, 80, 45, 70, 50, 40], }, { data: [50, 40, 60, 20, 45, 30, 60, 40, 45, 40, 50, 20, 60, 80, 45, 70, 50, 40], type: 'pictorialBar', barMaxWidth: '20', symbolPosition: 'end', symbol: 'image://' + barImg, symbolOffset: ['0', '-25'], symbolSize: [35, 35], zlevel: 2, }, ], } option.title.text = '当前各二级企业本部员额数' myChart.setOption(option) }, // 中间图表---------------------------------------------开始 initChartC1() { let myChart = echarts.init(this.$refs['echartC1']) let option = { ..._.cloneDeep(this.commonOption), series: [ { name: '全员劳动生产率', type: 'line', yAxisIndex: 1, //使用的 y 轴的 index,在单个图表实例中存在多个 y轴的时候有用 smooth: true, //平滑曲线显示 showAllSymbol: true, //显示所有图形。 symbol: 'circle', //标记的图形为实心圆 symbolSize: 8, //标记的大小 smooth: false, itemStyle: { //折线拐点标志的样式 color: '#B889EA', borderColor: '#B889EA', width: 2, shadowColor: '#B889EA', shadowBlur: 4, }, lineStyle: { color: '#B889EA', width: 2, }, data: [60, 50, 80, 80, 90, 55, 40, 60, 50, 80, 90, 55, 40, 60, 50, 90, 55, 40], }, { name: '全员劳动生产率同比', type: 'bar', barWidth: 15, itemStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [ { offset: 0, color: '#69c0ff', }, { offset: 1, color: '#082550', }, ]), }, }, data: [50, 40, 60, 20, 45, 30, 60, 100, 45, 40, 50, 20, 60, 80, 45, 70, 50, 40], }, ], } option.title.text = '各集团全员劳动生产率情况' option.legend.data = ['全员劳动生产率同比', '全员劳动生产率'] option.legend.show = true option.yAxis.push({ splitLine: { show: false, }, axisLine: { show: false, }, }) myChart.setOption(option) }, initChartC2() { let myChart = echarts.init(this.$refs['echartC2']) let option = { ..._.cloneDeep(this.commonOption), series: [ { name: '计划招聘数', type: 'line', yAxisIndex: 1, //使用的 y 轴的 index,在单个图表实例中存在多个 y轴的时候有用 smooth: true, //平滑曲线显示 showAllSymbol: true, //显示所有图形。 symbol: 'circle', //标记的图形为实心圆 symbolSize: 8, //标记的大小 smooth: false, itemStyle: { //折线拐点标志的样式 color: '#B889EA', borderColor: '#B889EA', width: 2, shadowColor: '#B889EA', shadowBlur: 4, }, lineStyle: { color: '#B889EA', width: 2, }, data: [60, 50, 80, 80, 90, 55, 40, 60, 50, 80, 90, 55, 40, 60, 50, 90, 55, 40], }, { name: '年利润亿元', type: 'bar', barWidth: 15, itemStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [ { offset: 0, color: '#69c0ff', }, { offset: 1, color: '#082550', }, ]), }, }, data: [50, 40, 60, 20, 45, 30, 60, 100, 45, 40, 50, 20, 60, 80, 45, 70, 50, 40], }, ], } option.title.text = '各省属企业年利润与当前计划招聘人数' option.legend.data = ['年利润亿元', '计划招聘数'] option.legend.show = true option.yAxis.push({ splitLine: { show: false, }, axisLine: { show: false, }, }) myChart.setOption(option) }, // 右侧图表---------------------------------------------开始 initChartR1() { let myChart = echarts.init(this.$refs['echartR1']) let option = { ...this.commonOption, series: [ { name: '公开招聘数', type: 'line', yAxisIndex: 1, //使用的 y 轴的 index,在单个图表实例中存在多个 y轴的时候有用 smooth: true, //平滑曲线显示 showAllSymbol: true, //显示所有图形。 symbol: 'circle', //标记的图形为实心圆 symbolSize: 8, //标记的大小 smooth: false, itemStyle: { //折线拐点标志的样式 color: '#B889EA', borderColor: '#B889EA', width: 2, shadowColor: '#B889EA', shadowBlur: 4, }, lineStyle: { color: '#B889EA', width: 2, }, data: [60, 50, 80, 80, 90, 55, 40, 60, 50, 80, 90, 55, 40, 60, 50, 90, 55, 40], }, { name: '退出人数', type: 'bar', barWidth: 10, itemStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [ { offset: 0, color: '#69C0FF', }, { offset: 1, color: '#082550', }, ]), }, }, data: [50, 40, 60, 20, 45, 30, 60, 100, 45, 40, 50, 20, 60, 80, 45, 70, 50, 40], }, ], } option.title.text = '当前各二级企业退出人数与公开招聘人数对比' option.legend.data = ['退出人数', '公开招聘数'] option.yAxis.push({ splitLine: { show: false, }, axisLine: { show: false, }, }) myChart.setOption(option) }, initChartR2() { let myChart = echarts.init(this.$refs['echartR2']) let option = { ...this.commonOption, series: [ { name: '薪酬', type: 'line', yAxisIndex: 1, //使用的 y 轴的 index,在单个图表实例中存在多个 y轴的时候有用 smooth: true, //平滑曲线显示 showAllSymbol: true, //显示所有图形。 symbol: 'circle', //标记的图形为实心圆 symbolSize: 8, //标记的大小 smooth: false, itemStyle: { //折线拐点标志的样式 color: '#B889EA', borderColor: '#B889EA', width: 2, shadowColor: '#B889EA', shadowBlur: 4, }, lineStyle: { color: '#B889EA', width: 2, }, areaStyle: { //区域填充样式 normal: { color: new echarts.graphic.LinearGradient( 0, 0, 0, 1, [ { offset: 0, color: '#B889EA', }, { offset: 1, color: 'rgba(0,0,0,0)', }, ], false ), }, }, data: [60, 50, 40, 90, 30, 55, 40, 20, 50, 40, 40, 55, 40, 30, 50, 40, 35, 40], } ], } option.title.text = '当前各二级企业在岗职工平均薪酬' option.legend.data = ['薪酬'] option.legend.show = true myChart.setOption(option) }, initChartR3() { let myChart = echarts.init(this.$refs['echartR3']) let option = { ...this.commonOption, series: [ { name: '任期值', type: 'line', yAxisIndex: 1, //使用的 y 轴的 index,在单个图表实例中存在多个 y轴的时候有用 smooth: true, //平滑曲线显示 showAllSymbol: true, //显示所有图形。 symbol: 'circle', //标记的图形为实心圆 symbolSize: 8, //标记的大小 smooth: false, itemStyle: { //折线拐点标志的样式 color: '#fbe138', borderColor: '#fbe138', width: 2, shadowColor: '#fbe138', shadowBlur: 4, }, lineStyle: { color: '#fbe138', width: 2, }, data: [60, 50, 80, 80, 90, 55, 40, 60, 50, 80, 90, 55, 40, 60, 50, 90, 55, 40], }, { name: '全员劳动合同签约率', type: 'bar', barWidth: 10, itemStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [ { offset: 0, color: '#69C0FF', }, { offset: 1, color: '#082550', }, ]), }, }, data: [50, 40, 60, 20, 45, 30, 60, 100, 45, 40, 50, 20, 60, 80, 45, 70, 50, 40], }, { name: '全员绩效考核', type: 'bar', barWidth: 10, itemStyle: { normal: { color: new echarts.graphic.LinearGradient(0, 0, 0, 1, [ { offset: 0, color: '#43ede3', }, { offset: 1, color: '#082550', }, ]), }, }, data: [60, 50, 40, 90, 30, 55, 40, 20, 50, 40, 40, 55, 40, 30, 50, 40, 35, 40], }, ], } option.title.text = '当前各二级企业本部员额数' option.legend.data = ['全员劳动合同签约率','全员绩效考核', '任期值'] option.yAxis.push({ splitLine: { show: false, }, axisLine: { show: false, }, }) myChart.setOption(option) }, }, })