react echarts tooltip 區(qū)域新加輸入框編輯保存數(shù)據(jù)功能
// demo頁(yè)面
// 需求:產(chǎn)品要求在折線圖的tooltip上新加一個(gè)輸入框,可以編輯這個(gè)輸入框保存?zhèn)渥⑿畔?,需要兩種交互方式: 1.鼠標(biāo)滑過(guò)展示備注信息。2.鼠標(biāo)點(diǎn)擊某一個(gè)日期時(shí),鼠標(biāo)可以滑到tooltip上做保存/編輯操作。
// 思路:1.保留初始鼠標(biāo)滑過(guò)echarts圖效果。
// 2.主要難點(diǎn)是點(diǎn)擊時(shí)tooltip固定可編輯,有嘗試通過(guò)動(dòng)態(tài)改變echarts自帶tooltip的顯示隱藏,但是效果并不好,并且因?yàn)閞eact是虛擬dom, 所以在react中沒(méi)辦法使用on監(jiān)聽(tīng)事件,使用ReactEcharts也只是必須要點(diǎn)擊某一個(gè)symbol圓點(diǎn)才可以出發(fā)點(diǎn)擊事件,最后放棄使用自有api的想法
// 3.最終方案:用一個(gè)div包裹echarts, 然后在echarts的同級(jí)新建一個(gè)div用來(lái)用來(lái)模擬真實(shí)tooltip,通過(guò)鼠標(biāo)移入移出事件控制真實(shí)tooltip的顯示與隱藏。
// 思路大概就是這樣,下面就是代碼部分的實(shí)現(xiàn)。因?yàn)榇隧?yè)面只是用來(lái)當(dāng)做demo,所以只提供偽代碼
import * as echarts from "echarts"; const [echartsParams, setEchartsParams] = useState([]); // tooltip formatter的params數(shù)據(jù) const [echartsData, setEchartsData] = useState({}); // 編輯或保存時(shí)輸入框的數(shù)據(jù) const [chart, setChart] = useState(); // 記錄當(dāng)前echarts, 鼠標(biāo)移入移出時(shí)控制tooltip顯示隱藏 const [chartAllData, setChartAllData] = useState(); // echaers數(shù)據(jù)源 const save = (date, id) => { const value = echartsData.annotation; const url = id === null ?。?axios('/save', { method: 'post', data: { date, annotation: value } }) : axios('/update', { method: 'post', data: { date, annotation: value, id, } }) } window.save = save; // 必須掛載在window上 // echarts。 data: 數(shù)據(jù)源 const initCharts = (data) => { setChartAllData(data) let option = { tooltip: { className: 'chartsTooltip', trigger: "axis", enterable: true, appendToBody: true, axisPointer: { type: "line", label: { backgroundColor: "#6a7985", }, }, formatter: (params) => { setEchartsParams(params); let str = ''; const annotation = data.filter((v) => v.time === params[0].name)[0].annotation || { annotation: '', id: null }; params.forEach((item) => { str += '<div class="box">' + `<div>${item.marker + item.seriesName}</div>` + `<div>${item.value}</div>` + '</div>'; }) return `<div class="test" id="tooltipDom"> ${params[0].name} <br /> ${str} <textarea class="ipt" id="inputId">${annotation.annotation}</textarea> <p onclick='save("${params[0].name}", "${annotation.id}")' class="save-btn">保存</p> </div>` }, }, } let Chart = echarts.getInstanceByDom( document.getElementById("enterprise-ratio") ); //有的話就獲取已有echarts實(shí)例的DOM節(jié)點(diǎn)。 if (Chart) { // 如果不存在,就進(jìn)行初始化。 Chart.clear(); } else { Chart = echarts.init(document.getElementById("enterprise-ratio")); } Chart.setOption(option); setChart(Chart); } return( <div // 最外層的盒子 onMouseLeave={() => { chart.dispatchAction({ type: 'showTip', }) chart.setOption({ tooltip: { show: true, }, }) const chartsTooltip = document.getElementsByClassName('chartsTooltip')[0]; if (chartsTooltip) { chartsTooltip.style.display = 'none'; } const tooltipId = document.getElementById('tooltipId') if (tooltipId) { tooltipId.style.display = 'none'; } > <div>這是這個(gè)區(qū)域的標(biāo)題</div> <div className="echarts-content" onClick={() => { chart.dispatchAction({ type: 'hideTip', }) chart.setOption({ tooltip: { show: false, }, }) const annotationData = chartAllData.filter((v) => v.time === echartsParams[0].name)[0].annotation || { annotation: '', id: null }; // annotation: '后端接口返回的數(shù)據(jù)', id: '編輯時(shí)需要的id, 根據(jù)id是否未null判斷是要保存還是編輯' setEchartsData(annotationData) const tooltipId = document.getElementById('tooltipId') if (tooltipId) { tooltipId.style.display = 'block'; } }} > { echartsParams.length ? ( <div className="tooltip-box" id="tooltipId"> {echartsParams[0].name} { echartsParams.map((item, i) => { return ( <div className="box" key={i}> <> <div> <span dangerouslySetInnerHTML={{ __html: item.marker }}></span> <span>{item.seriesName}</span> </div> <div>{item.value}</div> </> </div> ) }) } <Input.TextArea value={echartsData.annotation} className="ipt" onChange={(e) => { const v = e.target.value; echartsData.annotation = v; setEchartsData({ ...echartsData }) }} ></Input.TextArea> <p onClick={() => save(echartsParams[0].name, echartsData.id)} className="save-btn">保存</p> </div> ) : '' } <div className="flex-1" id="enterprise-ratio" style={{ height: '200px', width: '100%' }}></div> // echarts折線圖 </div> </div> )
到此這篇關(guān)于react echarts tooltip 區(qū)域新加一個(gè)輸入框,可以編輯保存數(shù)據(jù)的文章就介紹到這了,更多相關(guān)react echarts tooltip內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
react 跳轉(zhuǎn)后路由變了頁(yè)面沒(méi)刷新的解決方案
最近在學(xué)習(xí)React的過(guò)程中遇到了路由跳轉(zhuǎn)后頁(yè)面不刷新的問(wèn)題,本文就詳細(xì)的介紹一下解決方法,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-06-06useEvent顯著降低Hooks負(fù)擔(dān)的原生Hook
這篇文章主要為大家介紹了useEvent顯著降低Hooks負(fù)擔(dān)的原生Hook示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-07-07React中使用collections時(shí)key的重要性詳解
這篇文章主要給大家介紹了關(guān)于在React.js中使用collections時(shí)key的重要性,注意:一定不能不能忘了key,文中通過(guò)示例代碼介紹的非常詳細(xì),需要的朋友可以參考借鑒,下面跟著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧。2017-08-08如何在 React 中調(diào)用多個(gè) onClick 函數(shù)
這篇文章主要介紹了如何在React中調(diào)用多個(gè)onClick函數(shù),本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友參考下吧2023-11-11react基于Ant Desgin Upload實(shí)現(xiàn)導(dǎo)入導(dǎo)出
本文主要介紹了react基于Ant Desgin Upload實(shí)現(xiàn)導(dǎo)入導(dǎo)出,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2024-01-01Ant?Design?組件庫(kù)按鈕實(shí)現(xiàn)示例詳解
這篇文章主要介紹了Ant?Design?組件庫(kù)按鈕實(shí)現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪</P><P><BR>2022-08-08