首页 > 解决方案 > 未显示为 PNG 的 React 导出组件

问题描述

我正在尝试将图表导出到图像,并且我希望图表图像具有未显示在屏幕上的自定义图例。

我怎样才能做到这一点?

现在我尝试使用 react-component-export-image 导出,但如果组件未显示,则 ref 为 null 并且无法导出。请参阅组件导出实现src-code

我当前代码的示例:codesandbox

标签: javascriptreactjschart.jsreact-chartjsexport-to-image

解决方案


通过在渲染之前操作画布来实现这一点的唯一方法。您可以通过在 中设置onclone选项来做到这一点html2CanvasOptions

import { Line } from "react-chartjs-2";
import { exportComponentAsPNG } from "react-component-export-image";
import React, { useRef } from "react";
import { data } from "./data";

const Chart = React.forwardRef((props, ref) => {
  return (
    <div ref={ref} style={{ maxWidth: "800px" }}>
      <Line data={data} height={80} />
      <div id="legend" style={{ textAlign: "center", visibility: "hidden" }}>
        Legend
      </div> {/* Visibility set to hidden using css */}
    </div>
  );
});

const App = () => {
  const componentRef = useRef();

  return (
    <React.Fragment>
      <Chart ref={componentRef} />
      <button
        style={{ margin: "30px" }}
        onClick={() => exportComponentAsPNG(componentRef, {
            html2CanvasOptions: {
              onclone: (clonedDoc) => {
                clonedDoc.getElementById("legend").style.visibility = "visible";
                // Visibility set to visible using `onclone` method
              },
            },
          })
        }
      >
        Export As PNG
      </button>
    </React.Fragment>
  );
};

export default App;

https://codesandbox.io/s/export-chart-821kc?file=/src/App.js

这将完成这项工作。如果您需要进一步的支持,请告诉我。


推荐阅读