TypeScript - 元组
Posted xjy20170907
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了TypeScript - 元组相关的知识,希望对你有一定的参考价值。
数组合并了相同类型的对象,而元组(Tuple)合并了不同类型的对象。定义一对值分别为 string
和 number
的元组:
let xcatliu: [string, number] = [‘Xcat Liu‘, 25];
当赋值或访问一个已知索引的元素时,会得到正确的类型:
let xcatliu: [string, number]; xcatliu[0] = ‘Xcat Liu‘; xcatliu[1] = 25; xcatliu[0].slice(1); xcatliu[1].toFixed(2);
也可以只赋值其中一项:
let xcatliu: [string, number]; xcatliu[0] = ‘Xcat Liu‘;
但是当直接对元组类型的变量进行初始化或者赋值的时候,需要提供所有元组类型中指定的项。
let xcatliu: [string, number]; xcatliu = [‘Xcat Liu‘, 25]; let xcatliu: [string, number] = [‘Xcat Liu‘]; // index.ts(1,5): error TS2322: Type ‘[string]‘ is not assignable to type ‘[string, number]‘. // Property ‘1‘ is missing in type ‘[string]‘. let xcatliu: [string, number]; xcatliu = [‘Xcat Liu‘]; xcatliu[1] = 25; // index.ts(2,1): error TS2322: Type ‘[string]‘ is not assignable to type ‘[string, number]‘. // Property ‘1‘ is missing in type ‘[string]‘.
当添加越界的元素时,它的类型会被限制为元组中每个类型的联合类型:
let xcatliu: [string, number]; xcatliu = [‘Xcat Liu‘, 25]; xcatliu.push(‘http://xcatliu.com/‘); xcatliu.push(true); // index.ts(4,14): error TS2345: Argument of type ‘boolean‘ is not assignable to parameter of type ‘string | number‘. // Type ‘boolean‘ is not assignable to type ‘number‘.
以上是关于TypeScript - 元组的主要内容,如果未能解决你的问题,请参考以下文章
typescript Angular 2测试片段。代码库https://developers.livechatinc.com/blog/category/programming/angular-2/
typescript Angular最终版本的Angular 2测试片段。代码库https://developers.livechatinc.com/blog/category/programming
typescript Angular最终版本的Angular 2测试片段。代码库https://developers.livechatinc.com/blog/category/programming
typescript Angular最终版本的Angular 2测试片段。代码库https://developers.livechatinc.com/blog/category/programming