TS 自学笔记(一)

本文写于 2020 年 5 月 6 日

日常废话两句

有几天没有更新了,最近学的比较乱,休息了两天感觉好一些了。这两天玩了几个设计软件,过几天也写篇文章分享分享。

为啥要学 TS?

进入正题哈,经常写 JS 的人会特别多的碰到一个 bug:xxxx is not a function之类的。

这是为什么呢?

其实就是我们用了一些不属于它的方法。

比如说我们有一个const a = 250,然后我们让他a.filter(()=>{})

有人可能会说,那明明是一个 number 类型,我怎么可能给他 filter 呢?

我之前就犯过这个错误,我想让一个数组等于另一个被 push 一个新元素数组:

  1. let newArr = arr.push('hello');
  2. newArr.filter(() => {});

要知道,arr.push 的返回值是新的数组长度!让一个 number 类型去使用数组方法,自然是会报错的。

好吧,我知道这样似乎非常愚蠢,但是总而言之,在日常写 JS 的报错中,有大把大把的错因都是这种完全可以避免掉的问题

如果是 Java 或是 C#,编辑器在还没运行时就给会你划上红线,不会等到你运行了再去告诉你你错了。

这就是动态语言的毛病。

所以我们需要学习 TypeScript,用它来构建应用,节省时间。据说用了 TS,能有效减少 80%的 Bug(笑)

不管这是不是真的,从各个大框架对于 TS 的青睐程度来看,未来几年内,TS 必然会是绝对的热点之一!Angular 早早的就从 Angular.js 变成了 Angular(必须使用 TS);React 对 TS 极其友好;Vue3 也开始使用 TS 重写。

毕竟,现在已经不只是:

能被 JS 改写的终将被 JS 改写

而是:

能被 TS 改写的,终将被 TS 改写

01 变量类型

JS 是弱类型语言,TS 却不是。TS 拥有这些类型:

  1. 1. undefined
  2. 2. null
  3. 3. boolean
  4. 4. number
  5. 5. string
  6. 6. object
  7. 7. array
  8. ----️JS 有的,️JS 没有的----
  9. 8. tuple
  10. 9. enum
  11. 10. any
  12. 11. void
  13. 12. never

注:对于 JS 来说,数组就是 Object 类型,并且在 JS 中数据类型并不是小写,而是大写。

在 2020 年,JS 的数据类型增加了 BigInt 和 Symbol 两种。

number、string、boolean 没有什么特别好说的,和 JS 没什么区别,我来写几个我觉得比较重要的。

数组的声明

  1. let list: number[] = [1, 2, 3];
  2. let list_b: Array<number> = [1, 2, 3];

第一种方法不难理解,就是生命一个 number 数组。

第二种方法叫做数组泛型,即Array<元素类型>

什么叫做泛型呢?

如果我们有一个函数:

  1. function identity(arg: number): number {
  2. return arg;
  3. }

那这个时候,传入的变量就必须是数字。

考虑到可复用性的问题,我们可以使用泛型。

  1. function identity<T>(arg: T): T {
  2. return arg;
  3. }

identity 函数叫做泛型(注意,T 不是泛型!),因为它可以适用于多个类型。

T 是类型变量,它是一种特殊的变量,只用于表示类型而不是值。它可以帮助我们捕获用户传入的类型,让我们可以对这个类型加以利用。

如果我们不确定传入的参数类型,我们是完全可以通过 any 来实现的,但是 any 就会让我们丢失 T 这一信息。

enum 是成组常量的好用法!

  1. enum Hello {
  2. teacher: "老师好",
  3. classmate: "同学好",
  4. parents: "爸爸好",
  5. girlfriend: "刘好"
  6. }

一般情况,枚举类型会自动赋给自己常量值:

  1. enum Hello {
  2. teacher, // 0
  3. classmates, // 1
  4. parents, // 2
  5. girlfriend // 3
  6. }

我们也可以从中间打断这个赋值:

  1. enum Hello {
  2. teacher, // 0
  3. classmates, // 1
  4. parents = 5, // 5
  5. girlfriend // 6
  6. }

接下来会进行顺延。

从来没有的 Never 值

never 类型表示的是那些永不存在的值的类型,听起来就像个悖论——我如何列举一个不存在的值?

其实never 类型可以是抛出的异常,或根本就不会有返回值的函数的返回值类型。

  1. function error(message: string): never {
  2. throw new Error(message);
  3. }
  4. function fail() {
  5. return error('Something failed');
  6. }
  7. function infiniteLoop(): never {
  8. while (true) {}
  9. }

总体来讲大同小异,TS 补充了一些在别的语言中有过的常见数据类型,相信这一块对于 JS 开发者来说,不会是什么难题。

唯一的难题就是习惯,可不能老是使用 any 类型!

PS: 在命名变量的时候有一个小坑,变量名不能命名为name,因为会与 DOM 中的全局 window 对象下的 name 属性出现重名。

(未完待续)

TS 自学笔记(一)的更多相关文章

  1. TS 自学笔记(二)装饰器

    TS 自学笔记(二)装饰器 本文写于 2020 年 9 月 15 日 上一篇 TS 文章已经是很久之前了.这次来讲一下 TS 的装饰器. 对于前端而言,装饰器是一个陌生的概念,但是对于 Java.C# ...

  2. JAVA自学笔记18

    JAVA自学笔记18 1.Map接口: 1)功能: 2) Map<String,String>m=new HashMap<String,String>(); //添加元素,元素 ...

  3. JAVA自学笔记17

    JAVA自学笔记17 1.Map接口 1)概述 将键映射到值的对象,一个映射不能包含重复的键,每个键最多只能映射到一个值.可以存储键值对的元素 2)与Collection接口的不同: ①Map是双列的 ...

  4. JAVA自学笔记21

    JAVA自学笔记21 1.转换流 由于字节流操作中文不是非常方便,因此java提供了转换流 字符流=字节流+编码表 1)编码表 由字符及其对应的数值组成的一张表 图解: 2)String类的编码和解码 ...

  5. JAVA自学笔记23

    JAVA自学笔记23 1.多线程 1)引入: 2)进程 是正在运行的程序.是系统进行资源分配和调用的独立单位.每一个进程都有它自己的内存空间和系统资源. 多进程: 单进程的计算机只能做一件事情,而现在 ...

  6. TypeScript 入门自学笔记 — 类型断言(二)

    码文不易,转载请带上本文链接,感谢~ https://www.cnblogs.com/echoyya/p/14558034.html 目录 码文不易,转载请带上本文链接,感谢~ https://www ...

  7. 《Linux内核设计与实现》课本第四章自学笔记——20135203齐岳

    <Linux内核设计与实现>课本第四章自学笔记 进程调度 By20135203齐岳 4.1 多任务 多任务操作系统就是能同时并发的交互执行多个进程的操作系统.多任务操作系统使多个进程处于堵 ...

  8. 《Linux内核设计与实现》课本第三章自学笔记——20135203齐岳

    <Linux内核设计与实现>课本第三章自学笔记 进程管理 By20135203齐岳 进程 进程:处于执行期的程序.包括代码段和打开的文件.挂起的信号.内核内部数据.处理器状态一个或多个具有 ...

  9. 《Linux内核设计与实现》课本第十八章自学笔记——20135203齐岳

    <Linux内核设计与实现>课本第十八章自学笔记 By20135203齐岳 通过打印来调试 printk()是内核提供的格式化打印函数,除了和C库提供的printf()函数功能相同外还有一 ...

随机推荐

  1. resin服务之三---独立resin的配置

    独立resin的配置 关掉httpd服务: [root@data-1-1 ~]# killall httpd [root@data-1-1 ~]# lsof -i :80    ------>h ...

  2. nginx 负载均衡详解

    配置文件 upstream abc { server 192.168.2.188:8080 weight=1 max_fails=3 fail_timeout=30; 定义集群,weight=权重轮询 ...

  3. 如何将springboot工程打包成war包并且启动

    将项目打成war包,放入tomcat 的webapps目录下面,启动tomcat,即 可访问. 1.pom.xml配置修改 <packaging>jar</packaging> ...

  4. Spark学习摘记 —— Pair RDD行动操作API归纳

    本文参考 参考<Spark快速大数据分析>动物书中的第四章"键值对操作",本篇是对RDD转化操作和行动操作API归纳的最后一篇 RDD转化操作API归纳:https:/ ...

  5. Collection单列集合的继承关系(集合的层次结构)

  6. leedcode_13 罗马数字转整数

    罗马数字包含以下七种字符: I, V, X, L,C,D 和 M. 字符 数值I 1V 5X 10L 50C 100D 500M 1000例如, 罗马数字 2 写做 II ,即为两个并列的 1 .12 ...

  7. 学习笔记 - Sass的安装与使用手册

    最近因为工作需要,自学了Sass.现在将学习笔记整理在这里,供大家参考. 1. Sass的安装 Sass的编辑器安装方法有很多,大致能分为两种:应用程序(application)和命令行界面(comm ...

  8. 前端入门-day2(常见css问题及解答)

    写在前面 今天是入门前端的day2, 小伙伴们应该已经看了一些HTML的基础和CSS的基础了,是不是遇到了很多关于CSS的问题呢.因为HTML很少有太复杂的问题,所以直接写一篇关于CSS的常见问题及解 ...

  9. vue常用知识点总结

    感谢本文引用链接的各位大佬们,小菜鸟我只是个搬运工 1.谈一谈你理解的vue是什么样子的? vue是数据.视图分离的一个框架,让数据与视图间不会发生直接联系.MVVM 组件化:把整体拆分为各个可以复用 ...

  10. pydev+eclipse写python代码

    首先,下载pydev:PyDev for Eclipse - Browse /pydev at SourceForge.net (建议下载到本地,之前看其他文章时,进行了如下安装: 启动 Eclips ...