echarts柱狀圖的點擊事件代碼示例
先來一段簡潔的寫echarts圖表的代碼:
// 這樣獲取echarts的dom節(jié)點是因為:如果將柱狀圖封裝成了一個組件,在一個頁面中多次使用,若還是按常規(guī)獲取dom節(jié)點,會報一個警告 let charts = echarts.getInstanceByDom( document.getElementById(props.id) ) if (charts == null) { charts = echarts.init(document.getElementById(props.id)) } charts.clear() let option = { ... } charts.resize() charts.setOption(option)
如圖所示,如果柱狀圖需要有點擊事件: 但這只是點擊藍(lán)色柱條部分才會觸發(fā)點擊事件的寫法
myChart.on('click', function (params) { console.log(params) })
如果柱條沒有數(shù)據(jù),用上述方法點擊時將不會觸發(fā),如果無數(shù)據(jù)點擊背景也依舊想觸發(fā)點擊事件,就用下面方法:
charts.getZr().off('click') // 先取消點擊,再觸發(fā),免得造成連續(xù)抖動觸發(fā) charts.getZr().on('click', function (params) { // 這個部分照抄,你想通過點擊拿到的當(dāng)前柱條的數(shù)據(jù),都可以在下面這些屬性中拿到,如果我注釋沒有你想要的,需要console一下charts.getOption()查找對應(yīng)的屬性名 let pointInPixel = [params.offsetX, params.offsetY]; if (charts.containPixel('grid', pointInPixel)) { let pointInGrid = charts.convertFromPixel({ seriesIndex: 0 }, pointInPixel); let xIndex = pointInGrid[1]; // 索引 let handleIndex = Number(xIndex); let seriesObj = charts.getOption(); // 圖表object對象 let op = charts.getOption(); //獲得圖表中點擊的列 let dataY = op.yAxis[0].data[handleIndex]; //獲取點擊的列名 let dataX = seriesObj.series[0].data[handleIndex] // 獲取當(dāng)前點擊的柱條的數(shù)值 ... // 寫獲取到當(dāng)前點擊需要的數(shù)值后的操作 } })
另外,再補充一下劃過和劃出事件的寫法,屬性是一樣的,就是事件名比較獨特: mousemove mouseout
,這兩對應(yīng),必須這樣寫,寫其他的可能無效
// 劃過 charts.getZr().off('mousemove'); charts.getZr().on('mousemove', function(params) { })
// 劃出 charts.getZr().off('mouseout'); charts.getZr().on('mouseout', function(params) { })
總結(jié)
到此這篇關(guān)于echarts柱狀圖的點擊事件的文章就介紹到這了,更多相關(guān)echarts柱狀圖點擊事件內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
JavaScript中將字符串轉(zhuǎn)換為數(shù)字的七種方法總結(jié)
在js的使用中往往伴隨著有格式帶來的問題,下面這篇文章主要給大家介紹了關(guān)于JavaScript中將字符串轉(zhuǎn)換為數(shù)字的七種方法,文中通過示例代碼介紹的非常詳細(xì),需要的朋友可以參考下2022-09-09JavaScript數(shù)據(jù)結(jié)構(gòu)常見面試問題整理
在JavaScript中,數(shù)據(jù)結(jié)構(gòu)是指相互之間存在一種或多種特定關(guān)系的數(shù)據(jù)元素的集合,是帶有結(jié)構(gòu)特性的數(shù)據(jù)元素的集合。常用的數(shù)據(jù)結(jié)構(gòu)有:數(shù)組、列表、棧、隊列、鏈表、字典、集合等等2022-08-08淺析ES6的八進(jìn)制與二進(jìn)制整數(shù)字面量
這篇文章給大家介紹了ES6特性中的八進(jìn)制和二進(jìn)制整數(shù)字面量,介紹的挺不錯的現(xiàn)在分享給大家,有需要的可以參考借鑒。2016-08-08基于JS正則表達(dá)式實現(xiàn)模板數(shù)據(jù)動態(tài)渲染(實現(xiàn)思路詳解)
這篇文章主要介紹了基于JS正則表達(dá)式實現(xiàn)模板數(shù)據(jù)動態(tài)渲染 ,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-03-03