react echarts tooltip 區(qū)域新加輸入框編輯保存數(shù)據(jù)功能

// demo頁面
// 需求:產(chǎn)品要求在折線圖的tooltip上新加一個輸入框,可以編輯這個輸入框保存?zhèn)渥⑿畔?,需要兩種交互方式: 1.鼠標(biāo)滑過展示備注信息。2.鼠標(biāo)點擊某一個日期時,鼠標(biāo)可以滑到tooltip上做保存/編輯操作。
// 思路:1.保留初始鼠標(biāo)滑過echarts圖效果。
// 2.主要難點是點擊時tooltip固定可編輯,有嘗試通過動態(tài)改變echarts自帶tooltip的顯示隱藏,但是效果并不好,并且因為react是虛擬dom, 所以在react中沒辦法使用on監(jiān)聽事件,使用ReactEcharts也只是必須要點擊某一個symbol圓點才可以出發(fā)點擊事件,最后放棄使用自有api的想法
// 3.最終方案:用一個div包裹echarts, 然后在echarts的同級新建一個div用來用來模擬真實tooltip,通過鼠標(biāo)移入移出事件控制真實tooltip的顯示與隱藏。
// 思路大概就是這樣,下面就是代碼部分的實現(xiàn)。因為此頁面只是用來當(dāng)做demo,所以只提供偽代碼
import * as echarts from "echarts";
const [echartsParams, setEchartsParams] = useState([]); // tooltip formatter的params數(shù)據(jù)
const [echartsData, setEchartsData] = useState({}); // 編輯或保存時輸入框的數(shù)據(jù)
const [chart, setChart] = useState(); // 記錄當(dāng)前echarts, 鼠標(biāo)移入移出時控制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實例的DOM節(jié)點。
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>這是這個區(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: '編輯時需要的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ū)域新加一個輸入框,可以編輯保存數(shù)據(jù)的文章就介紹到這了,更多相關(guān)react echarts tooltip內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
flouting?ui定位組件完美替代ant?deisgn使用詳解
這篇文章主要為大家介紹了flouting?ui定位組件完美替代ant?deisgn使用詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-11-11
使用React hook實現(xiàn)remember me功能
相信大家在使用 React 寫頁面的時候都遇到過完成 Remember me 的需求吧!本文就將這個需求封裝在一個 React hook 中以供后續(xù)的使用,覺得有用的同學(xué)可以收藏起來以備不時之需,感興趣的小伙伴跟著小編一起來看看吧2024-04-04
TypeScript在React中的應(yīng)用技術(shù)實例解析
這篇文章主要為大家介紹了TypeScript在React中的應(yīng)用技術(shù)實例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-04-04
React-router 4 按需加載的實現(xiàn)方式及原理詳解
本篇文章主要介紹了React-router 4 按需加載的實現(xiàn)方式及原理詳解,非常具有實用價值,需要的朋友可以參考下2017-05-05
React 使用recharts實現(xiàn)散點地圖的示例代碼
這篇文章主要介紹了React 使用recharts實現(xiàn)散點地圖的示例代碼,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-12-12
react最流行的生態(tài)替代antdpro搭建輕量級后臺管理
這篇文章主要為大家介紹了react最流行的生態(tài)替代antdpro搭建輕量級后臺管理示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2022-08-08

