欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

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

 更新時間:2023年05月11日 11:20:45   作者:凹潤之之之  
這篇文章主要介紹了react echarts tooltip 區(qū)域新加輸入框編輯保存數(shù)據(jù)功能,大概思路是用一個div包裹echarts, 然后在echarts的同級新建一個div用來用來模擬真實tooltip,通過鼠標移入移出事件控制真實tooltip的顯示與隱藏,需要的朋友可以參考下

// demo頁面
// 需求:產(chǎn)品要求在折線圖的tooltip上新加一個輸入框,可以編輯這個輸入框保存?zhèn)渥⑿畔?,需要兩種交互方式: 1.鼠標滑過展示備注信息。2.鼠標點擊某一個日期時,鼠標可以滑到tooltip上做保存/編輯操作。
// 思路:1.保留初始鼠標滑過echarts圖效果。
// 2.主要難點是點擊時tooltip固定可編輯,有嘗試通過動態(tài)改變echarts自帶tooltip的顯示隱藏,但是效果并不好,并且因為react是虛擬dom, 所以在react中沒辦法使用on監(jiān)聽事件,使用ReactEcharts也只是必須要點擊某一個symbol圓點才可以出發(fā)點擊事件,最后放棄使用自有api的想法
// 3.最終方案:用一個div包裹echarts, 然后在echarts的同級新建一個div用來用來模擬真實tooltip,通過鼠標移入移出事件控制真實tooltip的顯示與隱藏。
// 思路大概就是這樣,下面就是代碼部分的實現(xiàn)。因為此頁面只是用來當做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(); // 記錄當前echarts, 鼠標移入移出時控制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) {
      // 如果不存在,就進行初始化。
      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ū)域的標題</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>
)

到此這篇關于react echarts tooltip 區(qū)域新加一個輸入框,可以編輯保存數(shù)據(jù)的文章就介紹到這了,更多相關react echarts tooltip內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!

相關文章

  • React 錯誤邊界組件的處理

    React 錯誤邊界組件的處理

    這篇文章主要介紹了React 錯誤邊界組件的處理,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2021-04-04
  • react 跳轉后路由變了頁面沒刷新的解決方案

    react 跳轉后路由變了頁面沒刷新的解決方案

    最近在學習React的過程中遇到了路由跳轉后頁面不刷新的問題,本文就詳細的介紹一下解決方法,需要的朋友們下面隨著小編來一起學習學習吧
    2021-06-06
  • React實現(xiàn)輪播圖效果

    React實現(xiàn)輪播圖效果

    這篇文章主要為大家詳細介紹了React實現(xiàn)輪播圖效果,使用react-slick組件,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • useEvent顯著降低Hooks負擔的原生Hook

    useEvent顯著降低Hooks負擔的原生Hook

    這篇文章主要為大家介紹了useEvent顯著降低Hooks負擔的原生Hook示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪
    2022-07-07
  • React中使用collections時key的重要性詳解

    React中使用collections時key的重要性詳解

    這篇文章主要給大家介紹了關于在React.js中使用collections時key的重要性,注意:一定不能不能忘了key,文中通過示例代碼介紹的非常詳細,需要的朋友可以參考借鑒,下面跟著小編來一起學習學習吧。
    2017-08-08
  • 如何在React項目中使用AntDesign

    如何在React項目中使用AntDesign

    我們在后臺管理系統(tǒng)React項目開發(fā)中會有Table表格、Form表單、List列表、Button按鈕等組件,這個時候我們可以使用AntDesign來減少開發(fā)中不必要的樣式問題,本文就介紹了eact項目中使用AntDesign,感興趣的可以了解一下
    2022-04-04
  • 如何在 React 中調(diào)用多個 onClick 函數(shù)

    如何在 React 中調(diào)用多個 onClick 函數(shù)

    這篇文章主要介紹了如何在React中調(diào)用多個onClick函數(shù),本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2023-11-11
  • react基于Ant Desgin Upload實現(xiàn)導入導出

    react基于Ant Desgin Upload實現(xiàn)導入導出

    本文主要介紹了react基于Ant Desgin Upload實現(xiàn)導入導出,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2024-01-01
  • Ant?Design?組件庫按鈕實現(xiàn)示例詳解

    Ant?Design?組件庫按鈕實現(xiàn)示例詳解

    這篇文章主要介紹了Ant?Design?組件庫按鈕實現(xiàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪</P><P><BR>
    2022-08-08
  • webpack3+React 的配置全解

    webpack3+React 的配置全解

    本篇文章主要介紹了webpack3+React 的配置全解,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-08-08

最新評論