我有这 3 个功能,除了一些非常小的差异外,它们几乎相同:
function toInt1(x: string): number { return parseInt(x, 10); }
const toInt2 = function (x: string): number { return parseInt(x, 10); };
const toInt3 = (x: string): number => parseInt(x, 10);
现在我是 TypeScript 的新手,但在 JS 领域,我更喜欢第三种,因为它最简洁且限制性最强(不this
,不提升函数名)。
但是,当我将 tslint 与此规则一起使用时(表面上看起来很合理,但也许我错了......):
"typedef": [
true,
"call-signature",
"parameter",
"arrow-parameter",
"property-declaration",
"variable-declaration",
"member-variable-declaration"
],
toInt2
我收到关于and的这些错误toInt3
:
expected variable-declaration: 'toInt2' to have a typedef
expected variable-declaration: 'toInt3' to have a typedef
似乎我可以通过复制所有类型来修复它:
const toInt2: (x: string) => number = function (x: string): number { return parseInt(x, 10); };
const toInt3: (x: string) => number = (x: string): number => parseInt(x, 10);
然而,这是非常冗长且没有吸引力的。这真的是最好的做事方式吗?