// PS: 饼图非常吃数据,想要好看的饼图,必须有合格的数据支持 // mock 数据 const dataArray = [ { name: '教师', num: 2000 }, { name: '医生', num: 2000 }, { name: '程序员', num: 2000 }, { name: '公务员', num: 2000 }, { name: '金融', num: 2000 }, { name: '客服', num: 2000 }, { name: '老板', num: 2000 }, { name: '其他', num: 2000 }, ] const dataArr = [ { name: '女', num: 50 }, { name: '男', num: 50 } ] // 计算总数 let total = dataArray.reduce((p,v) => { return p + v.num }, 0) const colorList = [ [{ offset: 0, color: 'rgba(173, 255, 248, 1)'}, { offset: 1, color: 'rgba(50, 255, 238, 1)'}], [{ offset: 0, color: 'rgba(177, 255, 237, 1)'}, { offset: 1, color: 'rgba(0, 233, 179, 1)'}], [{ offset: 0, color: 'rgba(178, 255, 191, 1)'}, { offset: 1, color: 'rgba(29, 246, 66, 1)'}], [{ offset: 0, color: 'rgba(248, 255, 163, 1)'}, { offset: 1, color: 'rgba(240, 255, 71, 1)'}], [{ offset: 0, color: 'rgba(255, 234, 149, 1)'}, { offset: 1, color: 'rgba(255, 213, 47, 1)'}], [{ offset: 0, color: 'rgba(255, 180, 145, 1)'}, { offset: 1, color: 'rgba(255, 126, 76, 1)'}], [{ offset: 0, color: 'rgba(255, 156, 150, 1)'}, { offset: 1, color: 'rgba(255, 96, 86, 1)'}], [{ offset: 0, color: 'rgba(178, 217, 255, 1)'}, { offset: 1, color: 'rgba(97, 187, 255, 1)'}], ] const colorList2 = [ [{ offset: 0, color: '#68d3ff'}, { offset: 1, color: '#bfecff'}], [{ offset: 0, color: '#ff938d'}, { offset: 1, color: '#ffdfdd'}], ] const color = [ 'rgba(50, 255, 238, 1)', 'rgba(0, 233, 179, 1)', 'rgba(29, 246, 66, 1)', 'rgba(240, 255, 71, 1)', 'rgba(255, 213, 47, 1)', 'rgba(255, 126, 76, 1)', 'rgba(255, 96, 86, 1)', 'rgba(97, 187, 255, 1)', ] const color2 = ['#00a7ec', '#ff564c'] // data数据 const echartData = dataArray.map((v, i) => ({ name: v.name, value: v.num, itemStyle: { color: { type: 'linear', colorStops: colorList[i] } }, label: { color: color[i] } })) const totalData = dataArr.map((v, i) => ({ name: v.name, value: v.num, itemStyle: { color: { type: 'linear', colorStops: colorList2[i] } }, label: { color: color2[i] } })) // tooltip const tooltip = { trigger: 'item', formatter: params => { return ` <div>${params.data.name}: ${params.data.value}</div> ` } } // series const series = [{ name: '性别比例', type: 'pie', center: ['50%', '50%'], radius: [0, '45%'], label: { fontSize: 16, position: 'inner', formatter: params => { return `{${params.name === '男'? 'a': 'b'}|}\n\n${params.percent.toFixed(0)}%` }, rich: { a: { width: 24, height: 34, backgroundColor: { image: ""}, }, b: { width: 24, height: 34, backgroundColor: { image: '' } } } }, selectedMode: 'single', data: totalData, },{ name: '从业人员统计', type: 'pie', radius: ['50%', '70%'], center: ['50%', '50%'], avoidLabelOverlap: false, label: { show: true, fontSize: 16, formatter: params => { let percent = (params.data.value / total) * 100 return `${percent.toFixed(1)}%` } }, labelLine: { show: true}, data: echartData, emphasis:{ labelLine: { itemStyle: { shadowColor: 'rgba(250,250,250,0.2)', shadowBlur: 20 }}, label: { fontSize: 24, formatter: params => { let percent = (params.data.value / total) * 100 return `${percent.toFixed(1)}%\n{a|${params.data.name}}` }, rich: { a: { fontSize: 12, align:'center' } } } } }] // 渲染 option = { tooltip, series, color, backgroundColor: 'rgba(0, 0, 0, .8)' }