基于vue+echarts實現(xiàn)柱狀圖漸變色效果(每個柱子顏色不同)
一、需要實現(xiàn)的效果圖

二、背景
Echarts的柱狀圖,由于默認所有柱子都是同一個顏色,且顏色為純色系,顯示效果不能滿足我們的設(shè)計稿要求,遂需要進行改造。
本文介紹如何為每個柱子添加不同的顏色,以及如何添加漸變色,以豐富圖表的顯示效果。
除了顏色的問題,同時存在以下幾個小問題會一同解決:
- 多數(shù)值柱狀圖;
- 帶圓角的柱狀圖;
三、解決思路
這是一個集多數(shù)值的柱狀圖、每個柱子的顏色不同,且每個柱子都有自己的漸變色、帶圓角的柱狀圖于一體的柱狀圖,就需要考慮代碼的整潔性和復用性。
由于柱子的寬度和y軸坐標值一樣,只是每個柱子的值、顏色、名稱不同,可以考慮將每個柱子的設(shè)置對象寫成公共方法,經(jīng)過傳值完成。
四、為每個柱子設(shè)置不同顏色,以及漸變色的設(shè)置
這個是在series中進行設(shè)置的,series是個數(shù)組,我們有四個柱子表示四種數(shù)據(jù),每個柱子對應數(shù)組中的一個對象,即series數(shù)組中包含了四個對象:

series: [
getBarSeriesData('telNoAnsweredCount'),
getBarSeriesData('emptyCount'),
getBarSeriesData('timeoutCount'),
getBarSeriesData('joinEmptyCount')
]
備注:為了提高代碼的可讀性和可拓展性,減少冗余代碼,此處將數(shù)組中的對象提取成一個公共方法,根據(jù)參數(shù)不同,顯示不同數(shù)據(jù)。
- 首先將每個柱子的配置對象寫成公共方法:
下圖是該公共方法的代碼內(nèi)容截圖,主要是將漸變色的色值(color)、柱子名稱(name)和數(shù)據(jù)(data)寫成變量:

附上代碼如下:
function getBarSeriesData(target: keyof typeof propDict): SeriesOption {
return {
name: propDict[target].name,
data: incomingCallTrendData.data.data[target],
tooltip: {
trigger: 'axis'
},
type: 'bar',
barWidth: '6', // 柱子寬度可自定義
roundCap: true,
itemStyle: {
borderRadius: [5, 5, 0, 0], // 帶圓角的柱子設(shè)置
color: {
type: 'linear',
x: 0,
y: 0,
x2: 0,
y2: 0.95,
colorStops: [
{
offset: 0,
color: propDict[target].colorStart, // 0% 處的顏色
},
{
offset: 1,
color: propDict[target].colorStop, // 100% 處的顏色
},
],
global: false, // 缺省為 false
},
}
}
}
- 將漸變色的顏色、柱子名稱(
name)進行自定義:

const propDict = {
telNoAnsweredCount: {
name: '客戶呼入隊列未接通數(shù)',
index: 0,
color: 'rgba(227, 103, 61, 1)',
colorStart: 'rgba(227, 103, 61, 1)',
colorStop: 'rgba(252, 70, 107, 1)'
},
emptyCount: {
name: '排隊無可用坐席溢出數(shù)',
index: 1,
color: 'rgba(239, 217, 171, 1)',
colorStart: 'rgba(239, 217, 171, 1)',
colorStop: 'rgba(221, 145, 123, 1)'
},
timeoutCount: {
name: '排隊超時溢出數(shù)',
index: 2,
color: 'rgba(2, 164, 255, 1)',
colorStart: 'rgba(2, 164, 255, 1)',
colorStop: 'rgba(5, 125, 210, 1)'
},
joinEmptyCount: {
name: '進隊列前無座席溢出數(shù)',
index: 3,
color: 'rgba(19, 251, 157, 1)',
colorStart: 'rgba(250, 112, 170, 1)',
colorStop: 'rgba(102, 27, 221, 1)'
}
}
- 最后,在
series中進行調(diào)用即可。這樣不僅柱子是漸變色,而且每個圖例也會自動變成漸變色。
在series數(shù)組中的四個對象,就解決了多數(shù)值柱子的問題。相信看的仔細的同學也發(fā)現(xiàn)了柱子帶圓角的設(shè)置位置(borderRadius: [5, 5, 0, 0], // 帶圓角的柱子設(shè)置)。
五、總結(jié)
到此這篇關(guān)于基于vue+echarts實現(xiàn)柱狀圖漸變色效果(每個柱子顏色不同)的文章就介紹到這了,更多相關(guān)vue+echarts柱狀圖漸變色內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
el-radio-group中的area-hidden報錯的問題解決
本文主要介紹了el-radio-group中的area-hidden報錯的問題解決,下面就來介紹幾種解決方法,具有一定的參考價值,感興趣的可以了解一下2025-04-04
vue3項目中配置sass,vite報錯Undefined mixin問題
這篇文章主要介紹了vue3項目中配置sass,vite報錯Undefined mixin問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-02-02
vue+Element實現(xiàn)搜索關(guān)鍵字高亮功能
這篇文章主要為大家詳細介紹了vue+Element實現(xiàn)搜索關(guān)鍵字高亮功能,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-05-05
Vuex(多組件數(shù)據(jù)共享的Vue插件)搭建與使用
Vuex是實現(xiàn)組件全局狀態(tài)(數(shù)據(jù))管理的一種機制,可以方便的實現(xiàn)組件之間數(shù)據(jù)的共享,數(shù)據(jù)緩存等等,下面這篇文章主要給大家介紹了關(guān)于Vuex(多組件數(shù)據(jù)共享的Vue插件)搭建與使用的相關(guān)資料,需要的朋友可以參考下2022-10-10
vue結(jié)合el-upload實現(xiàn)騰訊云視頻上傳功能
這篇文章主要介紹了vue結(jié)合el-upload實現(xiàn)騰訊云視頻上傳功能,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-07-07
Vue.js實現(xiàn)一個自定義分頁組件vue-paginaiton
這篇文章主要為大家詳細介紹了Vue.js實現(xiàn)一個自定義分頁組件vue-paginaiton的具體代碼,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-09-09

