《从零开始TypeScript》系列 - 基础数据类型
TypeScript 是 JavaScript 的超集,这里我们只讨论两者中的不同的部分,或者需要注意的部分
数组 Array:在TypeScript中,有两种方式来定义一个数组:
在元素类型后面接上 [] ,表示此数组,是由该类型的元素所组成:
let list: number[] = [1, 2, 3]
使用数组泛型,意义是与第一种方式相同的
let list: Array<number> = [1, 2, 3]
总结: ts 与 js 中数组的区别在于,js 是一个弱类型的语言,所以 js 数组中的元素可以是不同类型的;但 ts 是不同的,严格意义上是不允许一个数组中的元素类型是不同的,如果非要这样做,可以将元素类型指定为 any 或者 let list: (string | number)[]
,不过这将失去严格的意义,因为数组(列表)的定义是:数组是在程序设计中,为了处理方便, 把具有相同类型的若干元素按无序的形式组织起来的一种形式,是用于储存多个相同类型数据的集合。
元组 Tuple:表示一个已知元素 数量、类型的数组,与数组的区别是,元组内各元素的类型不必相同。
创建一个元组:let x: [string, number] = ["hello", 123]
总结:ts 中的元组,不同于传统高级程序语言的元组的定义,首先它并不是一个“独立”的数据类型,因为使用Array.isArray(x)
返回的true;其次,其元素可以动态修改的。可以说,其在某种场景下,是对 js 数组的兼容写法。
枚举 enum:是对 js 标准数据类型的一个补充。
枚举类型的定义与取值:
`enum Sex { Male, Female }
let s: Sex = Sex[0] || let s: Sex = Sex.Male
`
总结:可以将其理解为特殊的数组,其索引值是初始时就已经定好了的,其使用场景一般是用来定义,有限取值范围的变量;如:一周只有七天,性别只有两个等等。
Any:表示任意类型,常用来在编程阶段我们还不确定这个变量的具体类型时,可以正常的通过编译,在我们弄清该变量在程序上下文中的关系后,在将其指定为具体的类型。
需要弄清楚的是: Any 与 Object 之间的区别,Object 具有与 Any 相似的作用,但它们有本质的区别,Object 类型的变量,只能够允许将其赋任何值,但不能在它上面调用任何的方法,即使它真的有这个方法也不行。
Void:表示没有任何类型,它与 Any 是有本质的区别的,它们的意义刚好相反。常用来表示一个没有任何返回值的函数的返回值类型。
function demo(): void {....}
Null 和 Undefined:它们是两种数据类型,它们分别只有一个值,就是其本身,所以将一个变量的类型指定为这两者中的任意一个都是没有意义的。只需要直接赋值即可。
Never:表示那些永远不存在的值的类型。常用来表示那些只要运行的就会抛出异常的函数的返回值类型。返回 never 的函数必须存在无法到达的终点。
类型断言:告诉编译器,“相信我,我知道我在做什么,不要给我报错了。。。。”; 相当于其它高级语言中的 类型转换。
例如:
`
let str: any = 'hello'
let len: number = (str).length
`
另一种写法:
`
let str: any = 'hello'
let len: number = (str as string).length
`
注意:本质上,这两种写法都是被认可的,但是在 JSX 中,只有第二种写法才被允许。
《从零开始TypeScript》系列 - 基础数据类型的更多相关文章
- TypeScript_基础数据类型
TypeScript 的基础数据类型包含: string.number.boolean.array .object.null.undefined.enmu.void.never.any.tuple 注 ...
- 《前端之路》 - 初试 TypeScript(一)基础数据类型
一.先讲讲 TypeScript 什么是 typeScript ? typeScript 是 Javascript 的超集 我们用一张图来简单介绍下 ts 和 js 清清楚楚明明白白的关系- 为什么会 ...
- TypeScript学习指南第一章--基础数据类型(Basic Types)
基础数据类型(Basic Types) 为了搭建应用程序,我们需要使用一些基础数据类型比如:numbers,strings,structures,boolean等等. 在TypeScript中除了Ja ...
- TypeScript基础数据类型
Typescript与Javascript 二者的区别 作为前端开发的基础语言javascript已经深入人心,人人皆知.作为变成入门的最简单语言,Javascript语言以动态.弱类型语言而著名,学 ...
- 四.python基础数据类型
一.什么是数据类型? 什么是数据类型? 我们人类可以很容易的分清数字与字符的区别,但是计算机并不能呀,计算机虽然很强大,但从某种角度上看又很傻,除非你明确的告诉它,1是数字,“汉”是文字,否则它是分不 ...
- TypeScript之基本数据类型
前言 最近项目很急,所以没有什么时间回答关于Xamarin.Android方面的问题,也有一段时间没有更新.主要是手头很缺人,如果有谁有兴趣加入我们的话,可以私聊我,这样我就能继续造福社区了,同时还有 ...
- SQL Server调优系列基础篇(常用运算符总结——三种物理连接方式剖析)
前言 上一篇我们介绍了如何查看查询计划,本篇将介绍在我们查看的查询计划时的分析技巧,以及几种我们常用的运算符优化技巧,同样侧重基础知识的掌握. 通过本篇可以了解我们平常所写的T-SQL语句,在SQL ...
- SQL Server调优系列基础篇(常用运算符总结)
原文:SQL Server调优系列基础篇(常用运算符总结) 前言 上一篇我们介绍了如何查看查询计划,本篇将介绍在我们查看的查询计划时的分析技巧,以及几种我们常用的运算符优化技巧,同样侧重基础知识的掌握 ...
- 从 JavaScript 到 TypeScript 系列
随着应用的庞大,项目中 JavaScript 的代码也会越来越臃肿,这时候许多 JavaScript 的语言弊端就会愈发明显,而 TypeScript 的出现,就是着力于解决 JavaScript 语 ...
随机推荐
- fiddler抓包+雷电模拟器 完成手机app抓包的配置
1.下载最新版Fiddler,强烈建议在官网下载:https://www.telerik.com/download/fiddler 不下载最新版的话,配置起来会遇到很多问题,弄太麻烦了.因为我下载的是 ...
- 计蒜客 第四场 C 商汤科技的行人检测(中等)平面几何好题
商汤科技近日推出的 SenseVideo 能够对视频监控中的对象进行识别与分析,包括行人检测等.在行人检测问题中,最重要的就是对行人移动的检测.由于往往是在视频监控数据中检测行人,我们将图像上的行人抽 ...
- JBoss 5.x和6.x 反序列化漏洞(CVE-2017-12149)
0x01 漏洞简介 该漏洞为 Java反序列化错误类型,存在于 Jboss 的 HttpInvoker 组件中的 ReadOnlyAccessFilter过滤器中.该过滤器在没有进行任何安全检查的情况 ...
- 用python写的一个自动卸载python包的脚本
import osplist=os.popen("pip list") # 执行windows cmd命令,获取所有包package列表,并获取返回结果到plist#跳过第1,2行 ...
- 基于vue3.0+electron新开窗口|Electron多开窗体|父子模态窗口
最近一直在折腾Vue3+Electron技术结合的实践,今天就来分享一些vue3.x和electron实现开启多窗口功能. 开始本文之前,先来介绍下如何使用vue3和electron来快速搭建项目. ...
- Lenet车牌号字符识别+保存模型
# 部分函数请参考前一篇或后一篇文章 import tensorflow as tf import tfrecords2array import numpy as np import matplotl ...
- Virtualbox 安装centos7虚拟机
Virtualbox 安装centos7虚拟机 一,下载centos7 下载地址:https://mirrors.tuna.tsinghua.edu.cn/centos/7.9.2009/isos/x ...
- vue template
vue template <template> <div class="custom-class"> ... </div> </templ ...
- TypeScript tuple 元组
TypeScript tuple 元组 元组类型允许您用固定数量的元素表示数组,这些元素的类型是已知的,但不必相同. "use strict"; /** * * @author x ...
- UML online tools
UML online tools UML https://www.diagrams.net/assets/svg/home-dia1.svg refs https://www.diagrams.net ...