我在将应用程序转换为typescript时遇到了一个小问题。以下是(缩短的)代码:
我有一个具有简单字符串属性的类型:
export type Person = {
birth_date: string
...
在使用react-table
:
import {useTable, useSortBy, Column} from 'react-table'
const PersonTable: FC<{persons: Person, columns: Column<Person>}> = ({ persons, columns }) => {
const { getTableProps, getTableBodyProps, headerGroups, rows, prepareRow } =
useTable<Person>({ columns, data: persons }, useSortBy)
...
因为birth_date的格式是YYYY-MM-DD,所以我想在定义列时将其更改为可读的内容,其中formatDate返回字符串:
const columnsPersons = useMemo(() => [
{
Header: 'Birth date',
accessor: (row: Person) => formatDate(row.birth_date)
}
], [])
但是当我设置
<PersonTable columns={columnsPersons} ...
我得到以下错误(缩短):
Type '{ Header: string; accessor: string; }' is not assignable to type '{ accessor: "birth_date"; }'.
Types of property 'accessor' are incompatible.
Type 'string' is not assignable to type '"birth_date"'.
我知道我可以使用函数作为访问器,因为这是可行的。但我不知道我是否使用和/或输入正确。如有任何帮助,不胜感激。
看起来您从formatDate返回的类型比访问器所期望的更宽。你应该从formatDate返回一个'birth_date'类型,而不是字符串。或者将列描述为{'从formatDate返回的内容':string}而不是{'birth_date': string}
// 1.
const formatDate = (date) => return date as 'birth_date'
// 2.
const formatDate = (date: string): 'another_birth_date' => { .... }
const PersonTable: FC<{persons: Person, columns: Column<{'another_birth_date': string}>