TypeScript进阶篇 --- 类型别名&&字符串字面量类型

本文探讨了JavaScript中的类型别名和字符串字面量类型,如何通过type定义新的类型名称,以及它们在联合类型和约束参数值的应用实例,帮助开发者理解和使用这些高级特性。

类型别名

类型别名用来给一个类型起个新名称。

简单的例子
    type Name = string ;
    type NameResolver = () => string;
    type NameOrNameResolver = Name | NameResolver ;
    function getName(n:NameOrNameResolver):Name{
        if(typeof n == 'string'){
            return n
        }
        return n()
    }

上例中,我们使用type创建类型别名。
类型别名常用于联合类型。

字符串字面量类型

字符串字面量类型用来约束取值只能是某几个字符串中的一个。

简单的例子
    type EventNames = 'click' | 'scroll' | 'mousemove';
    function handleEvent(ele: Element, event: EventNames) { }
    handleEvent(document.getElementById('hello'), 'scroll');  // 没问题
    handleEvent(document.getElementById('world'), 'dblclick'); // 报错,类型“"dblclick"”的参数不能赋给类型“EventNames”的参数。

上例中,我们使用type定义了一个字符串字面量类型EventNames,它只能取三种字符串中的一种。
注意,类型别名与字符串字面量类型都是type进行定义的。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值