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

  • 强类型不允许随意的隐士类型转换,而弱类型是允许的
  • 变量类型允许随时改变的特点,不是强弱类型的差异

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

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

JavaScript 自有类型系统的问题

  • 任性:缺失了类型系统的可靠性
  • javaScript没有编译环节,初期发展就设计成弱类型、动态类型语言
  • 大规模应用下,这种优势也是劣势

弱类型的问题

    • 君子约定有隐患,强制要求有保障
  • 强类型的优势
    • 错误更早暴露
    • 代码更只能,编程更准确
    • 重构更牢靠
    • 减少不必要的类型判断

Flow静态类型检查方案 (工具)

  • 参数-> 类型注解
  • 使用-> yarn add flow-bin --dev
  • flow编译移除注解-> yarn add flow-remove-types --dev
    • yarn flow-remove-types src -d dist
  • 使用babel代替flow工具
    • yarn add @babel/core @babel/cli @babel/preset-flow --dev
    • 项目中引入.babelrc 文件{“presets”: ["babel/preset-flow"]}
    • yarn babel src -d dist
  • vscode插件:flow-language-support 开箱即用
  • flow官网支持的编辑器 https://flow.org/en/docs/editors
  • flow 类型推断
    • 建议手动添加类型注解
    • 原始类型
      • const a: string = 'aax';
        const b: number = Infinity;
        const c: boolean = false;
        const d: null = null;
        const e: void = undefined;
        const f: symbol = Symbol();
    • 数组类型
      • const arr1: Array<number> = [1,2,3];
        
        const arr2: number[] = [1,2,3];

        // 元组 数组长度固定
        const arr3: [string, number] = ['hello', 123]
    • 对象类型
      • const obj1: {foo: String, bar: number} = {foo: 'string', bar: 100}
        
        const obj2: {foo?: String, bar: number} = { bar: 100 }
        
        const obj3: { [string]: string } = {}
        obj3.key1 = 'value1'
        obj3.key2 = 100
    • 函数类型

      • function foo(callback: (string, number) => void) {
        callback(string, 100)
        }
    • 字面量类型
      • const type: 'success' | 'warning' | 'danger' = 'success'
        
        type StringOrNumber = string | number
        
        const b: StringOrNumber = 'string' // 100
        
        const gender: ?number = null // undefined
        
        const gender2: number | null | void = null
    • mixed与any类型
      • 都是指定了任意类型,但是any是弱类型(主要是兼容老代码用的,实际项目中不建议使用),mixed是强类型。执行阶段会非法校验

类型手册:https://www.saltycrane.com/cheat-sheets/flow-type/latest/

运行环境API 对象

新手入门typeScript的更多相关文章

  1. 新手入门指导:Vue 2.0 的建议学习顺序

    起步 1. 扎实的 JavaScript / HTML / CSS 基本功.这是前置条件. 2. 通读官方教程 (guide) 的基础篇.不要用任何构建工具,就只用最简单的 <script> ...

  2. Flume NG Getting Started(Flume NG 新手入门指南)

    Flume NG Getting Started(Flume NG 新手入门指南)翻译 新手入门 Flume NG是什么? 有什么改变? 获得Flume NG 从源码构建 配置 flume-ng全局选 ...

  3. 原创:从零开始,微信小程序新手入门宝典《一》

    为了方便大家了解并入门微信小程序,我将一些可能会需要的知识,列在这里,让大家方便的从零开始学习:一:微信小程序的特点张小龙:张小龙全面阐述小程序,推荐通读此文: 小程序是一种不需要下载.安装即可使用的 ...

  4. 【原创】新手入门一篇就够:从零开发移动端IM

    一.前言 IM发展至今,已是非常重要的互联网应用形态之一,尤其移动互联网时代,它正以无与论比的优势降低了沟通成本和沟通代价,对各种应用形态产生了深远影响. 做为IM开发者或即将成为IM开发者的技术人员 ...

  5. 课程上线 -“新手入门 : Windows Phone 8.1 开发”

    经过近1个月的准备和录制,“新手入门 : Windows Phone 8.1 开发”系列课程已经在Microsoft 虚拟学院上线,链接地址为:http://www.microsoftvirtuala ...

  6. WordPress建站 新手入门

    WordPress建站 新手入门教程系列 1. WordPress入门 之 什么是WordPress? 2. WordPress入门 之 搭建WordPress站点需要什么条件? 3. WordPre ...

  7. 安卓自动化测试(2)Robotium环境搭建与新手入门教程

    Robotium环境搭建与新手入门教程 准备工具:Robotium资料下载 知识准备: java基础知识,如基本的数据结构.语法结构.类.继承等 对Android系统较为熟悉,了解四大组件,会编写简单 ...

  8. mongodb新手入门,mongodb命令学习

    下面来总结一下mongodb新手入门的常用命令吧.要是您是mongodb新手,可以看下. 1,show dbs 查询mongodb里面的数据库列表 如果想查看当前连接在哪个数据库下面,可以直接输入db ...

  9. iOS简易柱状图(带动画)--新手入门篇

    叨逼叨 好久没更新博客了,才几个月,发生了好多事情,处理了好多事情.不变的是写代码依然在继续. 做点啥子 看看objective-c的书,学着写了个柱状图,只是练习的demo而已,iOS上的图表控件已 ...

随机推荐

  1. 输入URL展示过程

    一. 输入URL,回车 敲击某个键时,键盘内的处理器会先对键矩阵进行分析,然后将数据发送到计算机 计算机接收到来自键盘的信号,由键盘控制器(一种集成电路)进行处理,发送给操作系统 操作系统会分析,这些 ...

  2. Linux下删除的文件如何恢复

    Linux下删除的文件如何恢复 参考自: [1]linux下误操作删除文件如何恢复 [2]Linux实现删除撤回的方法 以/home/test.txt为例 1.df -T 文件夹 找到当前文件所在磁盘 ...

  3. Linux启动初始化配置文件

    Linux启动初始化配置文件(1)/etc/profile 登录时,会执行. 全局(公有)配置,不管是哪个用户,登录时都会读取该文件. (2)/ect/bashrc Ubuntu没有此文件,与之对应的 ...

  4. MySQL(4):卸载MySQL

    MySQL的安装是比较复杂的,一旦安装出现错误或者出现其他问题,我们想要完全卸载MySQL也是非常麻烦的,下面简单说下怎样可以完全干净的卸载MySQL 卸载步骤 第一步:用管理员的身份打开命令窗口,关 ...

  5. redis入门到精通系列(六):redis的事务详解

    (一)事务的概念 谈到数据库的高级应用,不可避免会谈到事务.熟悉mysql的朋友们对事务肯定不陌生,简单来讲事务就是控制一个数据库操作序列要么全部执行要么全部不执行.今天我们就来了解redis中的事务 ...

  6. Mysql的基操

    创建一个数据库   (myschool是数据库名) create database myschool; 删除数据库 drop database myschool 创建一个表:(Student是 表名) ...

  7. 安装Java1.8教程图解

    在服务器上配置Java环境 第一步: 因为我们系统是centOS7 64位的,所以我下载的是最新版本的jdk X64位的 因为阿里云服务器事先就安装好了ssh,我们可以用xsell连上去,我把下载好的 ...

  8. 文件系统系列学习笔记 - inode/dentry/file/super(2)

    此篇文章主要介绍下linux 文件系统下的主要对象及他们之间的关系. 1 inode inode结构中主要包含对文件或者目录原信息的描述,原信息包括但不限于文件大小.文件在磁盘块中的位置信息.权限位. ...

  9. GSS API

    Detail:http://docs.oracle.com/cd/E24847_01/html/E22200/overview-61.html GSS-API 介绍 使用 GSS-API,程序员在编写 ...

  10. Axios的正确食用方法

    这里分享出我个人封装的一个axios,我会尽量每行注释,希望对大家有所帮助. 1. 安装 全局执行代码 npm install axios; 2. 编写全局axios文件(附件里有代码) 在src目录 ...