Ant Design Vue Table 列属性报错 Type ‘string‘ is not assignable to type ‘AlignType | undefined‘.

记录一个很奇葩的问题,使用 ant design vue table的时候,如果定义的 列数组不加类型限制,在 ts 或者 tsx里面,编译build会报错:

const columns = [
  {
    title: '资源名',
    dataIndex: 'name',
    key: 'name',
    align: "center",
    width: 120,
  },
  {
    title: '操作',
    key: 'action',
    align: "center",
    width: 120,
  },
]

  // 页面定义
<Table columns={this.columns} dataSource={this.datas} />

这个时候,如果本地运行 npm run dev是没问题的,但是在npm run build时候,就会报错,通不过TS的类型教研报错:

    Type '{ title: string; dataIndex: string; align: string; width: number; }' is not assignable to type 'ColumnType<any>'.
      Types of property 'align' are incompatible.
        Type 'string' is not assignable to type 'AlignType | undefined'.

而 AlignType 类型 又是 ant design vue 的内部类型,外边不能直接 import 引用,所以也不用不了下面的转换方案:

"center" as AlignType

修复方案,要使用如下的定义方案才可以,很简单就是给列定义加上类型限制:

        type TableDataType = string // table data的类型
        const columns: TableColumnType<TableDataType>[] = [
            {
                title: '资源名',
                dataIndex: 'name',
                key: 'name',
                align: "center",
                width: 120,
            },
            {
                title: '操作',
                key: 'action',
                align: "center",
                width: 120,
            },
        ]

整体感觉 TypeScript 的类型限制方案还有缺陷或者说不完美,要么就和 Java 强类型一样,用枚举限制某些值,真的没必要出现 Type 这种不伦不类的数据类型,还容易和 Interface 极度混淆,这对于非专业前端的后端来说真的是有点痛苦

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值