TypeScript基础笔记——never类型(TS -- 12)

简介: never类型(TS -- 12)


TypeScript将使用 never 类型来表示不应该存在的状态

返回never的函数必须存在无法达到的终点

functionerror(message:string):never {//因为必定抛出异常,所以 error 将不会有返回值

   thrownewError(message)

}

functionloop():never{

   while(true){

       //因为这个是死循环,永远不会去返回的

   }

}

interfaceA{

   type:"保安"

}

interfaceB{

   type:"草莓"

}

interfaceC{

   type:"卷心菜"

}

typeAll=A|B

functiontype(val:All){

   while(val.type){

       case"保安":break

       case"草莓":break

       //case "卷心菜":break

       default://兜底机制,此时C没有用上就会报错提示。这就算never的作用

       constcheck:never=val

       break

   }

}

Symbol类型

symbol 是一种新的原生类型,就像 numberstring 一样

symbol类型的值是通过Symbol构造函数创建的

可以传递参做为唯一标识 只支持 string 和 number 类型的参数

lets:symbol=Symbol('小满')

letnum:symbol=Symbol('小满')

letobj= {

   [num] ="value"//Symbol

   [s] ="草莓"//Symbol

   name:"小满"

   sex:"男"

}

console.log(obj.[num])//取到value

console.log(s,num)//返回Symbol(小满)Symbol(小满)

console.log(s===num)//false

//这个值看似一样,其实因为内存地址指针位置不同,所以是唯一值

for(letkeyinboj){

   console.log(key)

}//只会打印出name跟sex,[num]与[s]将打印不出来

console.log(Object.keys(obj))//["name","sex"]

console.log(Object.getOwnPropertyNames(obj))//["name","sex"],跟上面一样,打印不出来

console.log(JSON.stringify(obj));//["name":"小满","sex":"男"],一样打印不出来

能够读取到Symbol的两种方式

静态方法 Reflect.ownKeys() 返回一个由目标对象自身的属性键组成的数组(Array)。

语法:Reflect.ownKeys(target)   =>  target获取自身属性键的目标对象。

Reflect.ownKeys 方法返回一个由目标对象自身的属性键组成的数组。它的返回值等同于 Object.getOwnPropertyNames(target).concat(Object.getOwnPropertySymbols(target))

console.log(Object.getOwnPropertySymbol(obj));//能打印出来两个Symbol,另外两个普通的不会打印出来

Reflect.ownKeys()//此属性是将所有的属性都列出来

console.log(Reflect.ownKeys())//四个全部圆满的打印出来

目录
相关文章
|
4天前
|
JavaScript 安全 前端开发
TypeScript类型声明:基础与进阶
通过本文的介绍,我们详细探讨了TypeScript的基础与进阶类型声明。从基本数据类型到复杂的泛型和高级类型,TypeScript提供了丰富的工具来确保代码的类型安全和可维护性。掌握这些类型声明能够帮助开发者编写更加健壮和高效的代码,提高开发效率和代码质量。希望本文能为您在使用TypeScript时提供实用的参考和指导。
12 2
|
18天前
|
JavaScript 开发者
在 Babel 插件中使用 TypeScript 类型
【10月更文挑战第23天】可以在 Babel 插件中更有效地使用 TypeScript 类型,提高插件的开发效率和质量,减少潜在的类型错误。同时,也有助于提升代码的可理解性和可维护性,使插件的功能更易于扩展和升级。
|
29天前
|
JavaScript 前端开发
TypeScript【类型别名、泛型】超简洁教程!再也不用看臭又长的TypeScript文档了!
【10月更文挑战第11天】TypeScript【类型别名、泛型】超简洁教程!再也不用看臭又长的TypeScript文档了!
|
17天前
|
JavaScript 前端开发 安全
TypeScript进阶:类型系统与高级类型的应用
【10月更文挑战第25天】TypeScript作为JavaScript的超集,其类型系统是其核心特性之一。本文通过代码示例介绍了TypeScript的基本数据类型、联合类型、交叉类型、泛型和条件类型等高级类型的应用。这些特性不仅提高了代码的可读性和可维护性,还帮助开发者构建更健壮的应用程序。
22 0
|
2月前
|
JavaScript
typeScript进阶(9)_type类型别名
本文介绍了TypeScript中类型别名的概念和用法。类型别名使用`type`关键字定义,可以为现有类型起一个新的名字,使代码更加清晰易懂。文章通过具体示例展示了如何定义类型别名以及如何在函数中使用类型别名。
40 1
typeScript进阶(9)_type类型别名
|
2月前
|
JavaScript
typeScript基础(2)_any任意值类型和类型推论
本文介绍了TypeScript中的`any`任意值类型,它可以赋值为其他任何类型。同时,文章还解释了TypeScript中的类型推论机制,即在没有明确指定类型时,TypeScript如何根据变量的初始赋值来推断其类型。如果变量初始化时未指定类型,将被推断为`any`类型,从而允许赋予任何类型的值。
56 4
|
1月前
|
JavaScript 前端开发 安全
深入理解TypeScript:增强JavaScript的类型安全性
【10月更文挑战第8天】深入理解TypeScript:增强JavaScript的类型安全性
45 0
|
1月前
|
JavaScript 前端开发 开发者
深入理解TypeScript:类型系统与实用技巧
【10月更文挑战第8天】深入理解TypeScript:类型系统与实用技巧
|
2月前
|
JavaScript
typeScript基础(5)_对象的类型-interfaces接口
本文介绍了TypeScript中接口(interfaces)的基本概念和用法,包括如何定义接口、接口的简单使用、自定义属性、以及如何使用`readonly`关键字定义只读属性。接口在TypeScript中是定义对象形状的重要方式,可以规定对象的必有属性、可选属性、自定义属性和只读属性。
41 1
|
2月前
|
存储 JavaScript
typeScript进阶(11)_元组类型
本文介绍了TypeScript中的元组(Tuple)类型,它是一种特殊的数组类型,可以存储不同类型的元素。文章通过示例展示了如何声明元组类型以及如何给元组赋值。元组类型在定义时需要指定数组中每一项的类型,且在赋值时必须满足这些类型约束。此外,还探讨了如何给元组类型添加额外的元素,这些元素必须符合元组类型中定义的类型联合。
47 0