TypeScript语言

强类型与弱类型(类型安全)

强类型在语言层面限制函数的实参类型必须与形参类型相同;强类型语言中不允许有任意的数据隐式类型转换,但弱类型相反。

变量类型允许随时改变的特点,不是强弱类型的差异。

静态类型与动态类型(类型检查)

静态类型:一个变量声明时它的类型就是明确的,声明过后它的类型就不允许再修改。
动态类型:运行阶段才能够明确变量类型,而且变量的类型可以随时发生变化。

JavaScript自有类型系统的问题

弱类型的问题
  1. 由于js是脚本语言不存在编译环节,如果存在变量类型错误那么只有在运行时才会报错,如果存在耗时长的异步任务,那么这个错误很可能就会被忽略掉成为隐患;
  2. 多人协同开发时很可能会传递错误的参数类型出现bug,由于类型不明确就会造成函数功能发生改变;
  3. 出现对对象索引器错误的用法。
强类型的优势
  1. 错误更早暴露;
  2. 代码更智能,编码更准确;
  3. 重构更牢靠;
  4. 减少不必要的类型判断。

Flow静态类型检查方案

可以在变量后面增加: type对变量进行类型注解。

  • 使用步骤:

    1. 添加flow-bin;
    2. 在需要使用flow进行类型检查的文件头部增加如下注释标记;
    //@flow
    
    1. 为变量添加类型注解。
  • Flow编译移除注解

    1. 安装flow-remove-types
    2. 安装bable/core bable/cli babel/preset-flow
  • Flow开发工具插件
    Flow Language Support

  • Flow类型推断
    根据代码使用情况推断变量的类型。

  • Flow类型注解
    除了对函数参数进行类型注解外,还可以对变量和函数返回值类型进行类型注解。在括号后加上: type可以对函数返回值进行类型注解,如果返回值为空,那么类型为void

  • 原始类型
    string、number(NaN,Infinity无穷大)、boolean、null、undefined(用void表示)、symbol

  • 数组类型
    Array<number>、number[]
    元组:[string, number] 可用于函数返回多个参数

  • 对象类型
    { [string]: string }
    还可以在对象中指定任意键值对的类型,如果这个键值对可有可无那么加上?

  • 函数类型

  • 特殊类型
    字面量类型(一般配合联合类型使用);
    通过type关键字给类型使用别名或者用type单独声明一个类型;
    maybe类型。

  • Mixed & Any
    mixed为强类型,any为弱类型(尽量不使用,作用是为了兼容老代码)

  • 运行环境API

TypeScript语言规范与基本应用

TypeScript是ES6 JavaScript类型化的超集,相比于JavaScript多了类型校验系统和ES6标准。

  • 使用步骤:

    1. 安装typescript;
    2. 使用tsc(typescript compile)命令编译typescript文件,会检查代码中的类型使用异常、移除类型注解的扩展语法、自动转化ES新特性。
  • 配置文件
    使用yarn tsc --init自动生成配置文件。

  • ts标准库声明

标准库就是内置对象所对应的声明。

  • 中文错误消息
    使用yarn tsc --local zh-CN以中文显示错误消息。(不推荐)

  • 作用域问题

    • 可以使用立即执行函数,将变量放到函数作用域里;
    • 使用export将文件作为模块使用。
ts类型

建议为每个变量添加明确的类型。

  • 枚举类型
    用关键字enum声明,=进行赋值。如果不指定值则默认从0开始累加;第一个变量如果赋值数字,后面的变量也会在此基础上开始累加。
  • 任意类型
    any类型是不安全的,不要轻易使用。
  • 类型断言
接口

使用interface关键词声明,约束对象的结构。

  • 可选成员 ?:
  • 只读成员readonly
  • 动态成员[key: string]: string
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,240评论 6 498
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,328评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,182评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,121评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,135评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,093评论 1 295
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,013评论 3 417
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,854评论 0 273
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,295评论 1 310
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,513评论 2 332
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,678评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,398评论 5 343
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,989评论 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,636评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,801评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,657评论 2 368
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,558评论 2 352

推荐阅读更多精彩内容