我是TypeScript的新手,我想知道是否有一种很好的方法来重写代码,以避免在以下代码中出现TSLint错误"object access via string literals is disallowed“
interface ECType
{
name: string;
type: string;
elementType?: string;
}
export var fields: { [structName: string]: Array<ECType>; } = { };
class ECStruct1 {
foo: string;
bar: number;
baz: boolean;
qux: number;
quux: number;
corge: ECStruct2[];
grault: ECStruct2;
constructor() {
...
}
}
fields['ECStruct1'] = [
{ name: 'foo', type: 'string' },
{ name: 'bar', type: 'int' },
{ name: 'baz', type: 'bool' },
{ name: 'qux', type: 'long' },
{ name: 'quux', type: 'ulong' },
{ name: 'corge', type: 'array', elementType: 'ECStruct2' },
{ name: 'grault', type: 'ECStruct2' }
];
更新:最后,上面的内容将是一个超过300个ECStruct
的自生成文件的一部分,所以我希望有类定义(例如ECStruct1
)后跟它的元描述(例如fields['ECStruct1']
)。
发布于 2015-10-28 22:53:30
这里有几个选项:
1)只需禁用规则
/* tslint:disable:no-string-literal */
whatever.codeHere()
/* tslint:enable:no-string-literal */
2)使用变量而不是字符串文字
// instead of
fields['ECStruct1'] = ...
// do something like
let key = 'ECStruct1';
fields[key] = ...
3)编写/生成显式接口
参见MartylX's answer above。本质上:
interface ECFieldList {
ECStruct1: ECType[];
}
export var fields:ECFieldList = {
ECStruct1: [
...
这些都是合理的解决方案,尽管我不是#2的粉丝,因为它会毫无理由地破坏你的代码。如果你正在生成代码,也许像#3那样为fields
生成一个类型是一个很好的解决方案。
发布于 2019-02-13 12:50:21
你可以摆脱这个规则。在rules
::中查找tslint.json
,即使用false
添加属性"no-string-literal"
{
"rules": {
"no-string-literal": false,
... other rules ...
发布于 2019-07-23 02:49:37
只需使用模板文字注释。
fields[`ECStruct1`]
https://stackoverflow.com/questions/33387090
复制相似问题