使用echarts餅狀圖label既在內(nèi)部顯示數(shù)值(百分比),又顯示外部指示線
需求
項目開發(fā)中,產(chǎn)品經(jīng)理繪制的原型圖中,需要前端實(shí)現(xiàn)一個餅狀圖,且既在餅圖內(nèi)部中 顯示 百分比,又顯示 外部指示線及數(shù)值
效果如下圖所示:

查了下Echarts官網(wǎng)文檔
需要配置 series 下的 label 配置項
如下所示:
series: [
label: {
normal: {
position: 'inside' // 在內(nèi)部顯示,outseide 是在外部顯示
show: true,
formatter: '{c} // formatter 是標(biāo)簽內(nèi)容的格式器,用于轉(zhuǎn)換格式。支持 字符串和回調(diào)函數(shù)兩種形式。
}
}
]
其中,formatter 是標(biāo)簽內(nèi)容的格式器,用于轉(zhuǎn)換格式。
支持 字符串和回調(diào)函數(shù)兩種形式。
{c} 代辦字符串模板變量,表示數(shù)據(jù)值,常用的模板變量有:
- { a }:系列名
- { b }:數(shù)據(jù)名
- { c }:數(shù)據(jù)值
- { d }:百分比
問題來了
echarts 好像沒法直接配置成 內(nèi)部+外部 同時展示的情況。
因為在單個的 series 中(即其中的一個對象中),只能設(shè)置一個label。

不過也好解決
通過查看 echarts 官網(wǎng) series 配置項,可以看出,series 是一個數(shù)組(如上圖所示),既然單個中只能出現(xiàn)一個,那么我配置成 2個(多個)相同的對象,讓他們重合,就會出現(xiàn)兩個 label 標(biāo)簽,一個在內(nèi)部展示,一個在外部展示,就可以完美解決這種情況。
代碼實(shí)例如下所示:
series: [
{
type: 'pie',
radius: '90%',
data: [
{ value: data?.winBidNumber || 0, name: '中標(biāo)數(shù)量' },
{ value: data?.loseBidNumber || 0, name: '未中標(biāo)數(shù)量' },
{ value: data?.abandonBidNumber || 0, name: '棄標(biāo)數(shù)量' }
],
labelLine: {
show: true,
position: 'outside',
length: 10,
length2: 50
},
emphasis: {
itemStyle: {
shadowBlur: 10,
shadowOffsetX: 0,
shadowColor: 'rgba(0, 0, 0, 0.5)'
}
},
label: {
normal: {
position: 'outside',
show: true,
formatter: (d: any) => {
console.log(222, d);
return d.name + '(' + d.value + '次' +')'
}
}
}
},
{
type: 'pie',
radius: '90%',
data: [
{ value: data?.winBidNumber || 0, name: '中標(biāo)數(shù)量' },
{ value: data?.loseBidNumber || 0, name: '未中標(biāo)數(shù)量' },
{ value: data?.abandonBidNumber || 0, name: '棄標(biāo)數(shù)量' }
],
emphasis: {
itemStyle: {
shadowBlur: 10,
shadowOffsetX: 0,
shadowColor: 'rgba(0, 0, 0, 0.5)'
}
},
label: {
normal: {
position: 'inside',
show: true,
formatter: (d: any) => {
return d.percent + '%'
}
}
}
}
]
其中, labelLine 屬性 是 用來配置 外部指示線(第一段、第二段)的長度及樣式的。
formatter 為 回調(diào)函數(shù)的寫法如上面的代碼實(shí)例,該回調(diào)函數(shù)接收一個參數(shù),該參數(shù)的值包含了 模板字符串變量所擁有的值
如下圖打印的所示:

總結(jié)
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關(guān)文章
不用AJAX和IFRAME,說說真正意義上的ASP+JS無刷新技術(shù)
注明:以下方法都經(jīng)過實(shí)例和開發(fā)的長期驗證,其實(shí)這些技術(shù)早就有,今天只不過自己歸納一下2008-09-09
js form表單input框限制20個字符,10個漢字代碼實(shí)例
這篇文章主要介紹了js form表單input框限制20個字符,10個漢字,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-04-04
原生JavaScript實(shí)現(xiàn)的簡單省市縣三級聯(lián)動功能示例
這篇文章主要介紹了原生JavaScript實(shí)現(xiàn)的簡單省市縣三級聯(lián)動功能,結(jié)合完整實(shí)例形式分析了javascript聯(lián)動菜單的實(shí)現(xiàn)方法,涉及javascript事件響應(yīng)及頁面元素動態(tài)操作相關(guān)實(shí)現(xiàn)技巧,需要的朋友可以參考下2017-05-05
JavaScript實(shí)現(xiàn)給對象添加一個只讀屬性
這篇文章主要為大家介紹了JavaScript如何給對象加一個只讀屬性,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-06-06

