博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
TypeScript基础入门 - 接口 - 可索引的类型
阅读量:6317 次
发布时间:2019-06-22

本文共 1942 字,大约阅读时间需要 6 分钟。

hot3.png

转载地址

项目实践仓库

https://tag: 1.0.11

为了保证后面的学习演示需要安装下ts-node,这样后面的每个操作都能直接运行看到输出的结果。

npm install -D ts-node

后面自己在练习的时候可以这样使用

npx ts-node src/learn_basic_types.ts
npx ts-node 脚本路径

接口

TypeScript的核心原则之一是对值所具有的结构进行类型检查。 它有时被称做“鸭式辨型法”或“结构性子类型化”。 在TypeScript里,接口的作用就是为这些类型命名和为你的代码或第三方代码定义契约。

可索引的类型

与使用接口描述函数类型差不多,我们也可以描述那些能够“通过索引得到”的类型,比如a[10]或ageMap["daniel"]。 可索引类型具有一个 索引签名,它描述了对象索引的类型,还有相应的索引返回值类型。 让我们看一个例子:

interface SomeArray {    [index: number]: string;}let someArray: SomeArray;someArray = ["string1", "string2"];let str: string = someArray[0];console.log(str);

运行后结果如下

string1

上面例子里,我们定义了SomeArray接口,它具有索引签名。 这个索引签名表示了当用 number去索引SomeArray时会得到string类型的返回值。共有支持两种索引签名:字符串和数字。 可以同时使用两种类型的索引,但是数字索引的返回值必须是字符串索引返回值类型的子类型。 这是因为当使用 number来索引时,JavaScript会将它转换成string然后再去索引对象。 也就是说用 100(一个number)去索引等同于使用"100"(一个string)去索引,因此两者需要保持一致。

class Person {    name: string;}class Student extends Person {    className: string;}// 错误:使用数值型的字符串索引,有时会得到完全不同的Person!interface NotOkay {    // [x: number]: Person; // 数字索引类型“Person”不能赋给字符串索引类型“Student”    [x: string]: Student;}

字符串索引签名能够很好的描述dictionary模式,并且它们也会确保所有属性与其返回值类型相匹配。 因为字符串索引声明了 obj.property和obj["property"]两种形式都可以。 下面的例子里, name的类型与字符串索引类型不匹配,所以类型检查器给出一个错误提示:

interface SomeInterface {    [index: string]: string    // length: number    // 错误,`length`的类型与索引类型返回值的类型不匹配    name: string       // 可以,name是string类型}

最后,你可以将索引签名设置为只读,这样就防止了给索引赋值:

interface SomeInterface {    [index: string]: string    // length: number    // 错误,`length`的类型与索引类型返回值的类型不匹配    name: string       // 可以,name是string类型}interface ReadonlySomeArray {    readonly [index: number]: string;}let readonlyArray: ReadonlySomeArray = ["string1", "string2"];readonlyArray[2] = "string3"; // error!

运行后会得到如下错误提示

src/interface_6.ts(36,1): error TS2542: Index signature in type 'ReadonlySomeArray' only permits reading.

你不能设置readonlyArray[2],因为索引签名是只读的。

本实例结束实践项目地址

https://tag: 1.0.12

转载于:https://my.oschina.net/zhangdapeng89/blog/1922677

你可能感兴趣的文章
分析Ajax爬取今日头条街拍美图
查看>>
内存分布简视图
查看>>
如何学习虚拟现实技术vr? vr初级入门教程开始
查看>>
第4 章序列的应用
查看>>
初识闭包
查看>>
hdu1874畅通工程续
查看>>
rails 字符串 转化为 html
查看>>
AOP动态代理
查看>>
Yii2.0 下的 load() 方法的使用
查看>>
华为畅玩5 (CUN-AL00) 刷入第三方twrp Recovery 及 root
查看>>
[转] ReactNative Animated动画详解
查看>>
DNS原理及其解析过程
查看>>
没想到cnblog也有月经贴,其实C#值不值钱不重要。
查看>>
【转】LUA内存分析
查看>>
[转] Entity Framework Query Samples for PostgreSQL
查看>>
软件需求分析的重要性
查看>>
UVA465:Overflow
查看>>
HTML5-placeholder属性
查看>>
poj 2187:Beauty Contest(旋转卡壳)
查看>>
《Flask Web开发》里的坑
查看>>