Imr*_*qvi 2 html javascript reactjs
我正在使用 npm 包xlsx生成在表中有表的 excel 报告。一切正常,除了您可以在附加的屏幕截图中看到第 10 行与下面的所有表格相同。我确定我犯了一个 html 表错误,但两个小时后无法弄清楚错误究竟是什么。我附上了截图和html。
import React from 'react';
const Report = ({ data }) => {
// console.log(data);
return (
<table>
<tbody>
<tr>
<td style={{ width: '200px', backgroundColor: 'yellow' }}>
Source Name:
</td>
<td>SOme cool report</td>
</tr>
<tr>
<td>Report Name:</td>
<td colSpan='6'>
02 Dummy
</td>
</tr>
<tr />
<tr>
<td>Data Write:</td>
<td>Append to Previous Data</td>
</tr>
<tr>
<td>Download Date:</td>
<td>19/04/2021 13:16</td>
</tr>
<tr>
<td>SR Id:</td>
<td>99931</td>
</tr>
<tr>
<td>Data Period:</td>
<td> 2021/3</td>
</tr>
<tr>
<td>Report Period: </td>
<td>Monthly </td>
</tr>
<tr>
<td>sdfasdfasdf:</td>
<td>sdfsdf</td>
</tr>
<tr>
<td>
<table>
<tbody>
<tr>
<td></td>
<td colSpan='2'>Less than 1</td>
<td colSpan='2'>{'1-4'}</td>
<td colSpan='2'>{'5-9'}</td>
<td colSpan='2'>{'10-14'}</td>
<td colSpan='2'>{'15-19'}</td>
<td colSpan='2'>{'20-24'}</td>
<td colSpan='2'>{'25-44'}</td>
<td colSpan='2'>{'45-64'}</td>
<td colSpan='2'>{'65+'}</td>
</tr>
<tr>
<td>Dummy</td>
<td>Male</td> <td>Female</td>
<td>Male</td> <td>Female</td>
<td>Male</td> <td>Female</td>
<td>Male</td> <td>Female</td>
<td>Male</td> <td>Female</td>
<td>Male</td> <td>Female</td>
<td>Male</td> <td>Female</td>
<td>Male</td> <td>Female</td>
<td>Male</td> <td>Female</td>
</tr>
{Object.keys(data).map((d) => (
<tr>
<td>{d}</td>
<td>{data[d]?.abc?.male}</td>
<td>{data[d]?.abc?.female}</td>
<td>{data[d]?.cde1?.male}</td>{' '}
<td>{data[d]?.cde1?.female}</td>
<td>{data[d]?.cde2?.male}</td>{' '}
<td>{data[d]?.cde2?.female}</td>
<td>{data[d]?.cde3?.male}</td>
<td>{data[d]?.cde3?.female}</td>
<td>{data[d]?.abcd1?.male}</td>
<td>{data[d]?.abcd1?.female}</td>
<td>{data[d]?.abcd2?.male}</td>
<td>{data[d]?.abcd2?.female}</td>
<td>{data[d]?.ere1?.male}</td>
<td>{data[d]?.ere1?.female}</td>
<td>{data[d]?.ere2?.male}</td>
<td>{data[d]?.ere2?.female}</td>
<td>{data[d]?.ou?.male}</td>
<td>{data[d]?.ou?.female}</td>
</tr>
))}
</tbody>
</table>
</td>
</tr>
</tbody>
</table>
);
};
export default Report;
Run Code Online (Sandbox Code Playgroud)
嵌套表格 HTML 结构导致整个表格创建额外的行。
从您的代码中删除此行 - 这应该删除添加到 Excel 工作表中的额外行。
<table>
<tbody>
<tr>
Run Code Online (Sandbox Code Playgroud)
从你的代码。
请在此处查看更正后的代码(由于不支持的方法,您无法在代码和框上运行它 - 但代码可在本地设置上运行)
https://codesandbox.io/s/extrarowexcelsheet-333cv?file=/src/App.js
import React from "react";
import XLSX from "xlsx";
import { useRef } from "react";
const Report = () => {
// Data is just placeholder
const [data, setData] = React.useState([["Hello"], ["Bye"]]);
const myContainer = useRef(null);
const exportFile = () => {
const ws = XLSX.utils.table_to_sheet(myContainer.current);
const wb = XLSX.utils.book_new();
XLSX.utils.book_append_sheet(wb, ws, "SheetJS");
/* generate XLSX file and send to client */
XLSX.writeFile(wb, "sheetjs.xlsx");
};
return (
<div>
<h2> This is Demo for StackOverFlow Issue #68269850</h2>
<p> Extra row appearing in generated excel </p>
<button
style={{ backgroundColor: "#4CAF50", padding: "10px" }}
onClick={exportFile}
>
Press Me to Generate Excel Sheet{" "}
</button>
<hr />
<table ref={myContainer}>
<tbody>
<tr>
<td style={{ width: "200px", backgroundColor: "yellow" }}>
Source Name:
</td>
<td>SOme cool report</td>
</tr>
<tr>
<td>Report Name:</td>
<td colSpan="6">02 Dummy</td>
</tr>
<tr />
<tr>
<td>Data Write:</td>
<td>Append to Previous Data</td>
</tr>
<tr>
<td>Download Date:</td>
<td>19/04/2021 13:16</td>
</tr>
<tr>
<td>SR Id:</td>
<td>99931</td>
</tr>
<tr>
<td>Data Period:</td>
<td> 2021/3</td>
</tr>
<tr>
<td>Report Period: </td>
<td>Monthly </td>
</tr>
<tr>
<td>sdfasdfasdf:</td>
<td>sdfsdf</td>
</tr>
<tr>
<td></td>
<td colSpan="2">Less than 1</td>
<td colSpan="2">{"1-4"}</td>
<td colSpan="2">{"5-9"}</td>
<td colSpan="2">{"10-14"}</td>
<td colSpan="2">{"15-19"}</td>
<td colSpan="2">{"20-24"}</td>
<td colSpan="2">{"25-44"}</td>
<td colSpan="2">{"45-64"}</td>
<td colSpan="2">{"65+"}</td>
</tr>
<tr>
<td>Dummy</td>
<td>Male</td> <td>Female</td>
<td>Male</td> <td>Female</td>
<td>Male</td> <td>Female</td>
<td>Male</td> <td>Female</td>
<td>Male</td> <td>Female</td>
<td>Male</td> <td>Female</td>
<td>Male</td> <td>Female</td>
<td>Male</td> <td>Female</td>
<td>Male</td> <td>Female</td>
</tr>
{Object.keys(data).map((d) => (
<tr>
<td>{d}</td>
<td>{data[d]?.abc?.male}</td>
<td>{data[d]?.abc?.female}</td>
<td>{data[d]?.cde1?.male}</td> <td>{data[d]?.cde1?.female}</td>
<td>{data[d]?.cde2?.male}</td> <td>{data[d]?.cde2?.female}</td>
<td>{data[d]?.cde3?.male}</td>
<td>{data[d]?.cde3?.female}</td>
<td>{data[d]?.abcd1?.male}</td>
<td>{data[d]?.abcd1?.female}</td>
<td>{data[d]?.abcd2?.male}</td>
<td>{data[d]?.abcd2?.female}</td>
<td>{data[d]?.ere1?.male}</td>
<td>{data[d]?.ere1?.female}</td>
<td>{data[d]?.ere2?.male}</td>
<td>{data[d]?.ere2?.female}</td>
<td>{data[d]?.ou?.male}</td>
<td>{data[d]?.ou?.female}</td>
</tr>
))}
</tbody>
</table>
</div>
);
};
export default Report;
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
177 次 |
| 最近记录: |