Roy*_*evy 6 typescript react-table
我已经使用 Typescript 和 React-Table 设置了我的 React 项目。我按照React-Table 网站的快速入门指南进行操作,但遇到了错误。
const data = React.useMemo(
() => [
{
col1: 'Hello',
col2: 'World',
},
{
col1: 'react-table',
col2: 'rocks',
},
{
col1: 'whatever',
col2: 'you want',
},
],
[]
)
const columns = React.useMemo(
() => [
{
Header: 'Column 1',
accessor: 'col1', // accessor is the "key" in the data
},
{
Header: 'Column 2',
accessor: 'col2',
},
],
[]
)
Run Code Online (Sandbox Code Playgroud)
我在执行时遇到错误const tableInstance = useTable({ columns, data })。
类型 '{ 标头:字符串;访问器:字符串;}[]' 不可分配给类型 'readonly Column<{ col1: string; col2:字符串;}>[]'。类型 '{ 标头:字符串;访问器:字符串;}' 不可分配给类型 'Column<{ col1: string; col2:字符串;}>'。
我刚刚开始接触这个,所以我真的不知道发生了什么。这是一个重现问题的代码沙箱:Sandbox
Dra*_*g13 10
似乎 TypeScript 因类型推断而失败,所以我给了他提示
type Cols = { col1: string; col2: string };const columns: Column<Cols>[] = ...完整的工作示例在这里:
import { useTable, TableOptions, Column } from "react-table";
import React from "react";
type Cols = { col1: string; col2: string };
export default function App() {
const data = React.useMemo(
(): Cols[] => [
{
col1: "Hello",
col2: "World"
},
{
col1: "react-table",
col2: "rocks"
},
{
col1: "whatever",
col2: "you want"
}
],
[]
);
const columns: Column<{ col1: string; col2: string }>[] = React.useMemo(
() => [
{
Header: "Column 1",
accessor: "col1" // accessor is the "key" in the data
},
{
Header: "Column 2",
accessor: "col2"
}
],
[]
);
const options: TableOptions<{ col1: string; col2: string }> = {
data,
columns
};
const {
getTableProps,
getTableBodyProps,
headerGroups,
rows,
prepareRow
} = useTable(options);
return (
<table {...getTableProps()} style={{ border: "solid 1px blue" }}>
<thead>
{headerGroups.map((headerGroup) => (
<tr {...headerGroup.getHeaderGroupProps()}>
{headerGroup.headers.map((column) => (
<th
{...column.getHeaderProps()}
style={{
borderBottom: "solid 3px red",
background: "aliceblue",
color: "black",
fontWeight: "bold"
}}
>
{column.render("Header")}
</th>
))}
</tr>
))}
</thead>
<tbody {...getTableBodyProps()}>
{rows.map((row) => {
prepareRow(row);
return (
<tr {...row.getRowProps()}>
{row.cells.map((cell) => {
return (
<td
{...cell.getCellProps()}
style={{
padding: "10px",
border: "solid 1px gray",
background: "papayawhip"
}}
>
{cell.render("Cell")}
</td>
);
})}
</tr>
);
})}
</tbody>
</table>
);
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
15150 次 |
| 最近记录: |