当前位置: 首页 > article >正文

ts 类型分类

目录

01 ts 相关指令

02 类型声明空间与变量声明空间

03 类型注解和类型推断

04 类型分类 , 联合类型与交叉类型

05 never类型  any类型 和unknown类型


01 ts 相关指令

        全局安装 typescript 模块

                npm i -g typescript

        安装完成之后 可以将ts文件转换成js文件 

                tsc  xxx.ts 

         如果想要对转换的js文件进行实时转换 需要添加一个-w 参数

                tsc xxx.ts  -w

        ts 是默认全局环境下的,所以和其他文件夹中内容由同名变量会冲突

        需要把ts文件编程一个模块化的文件 那么变量就只能在这个模块中起作用就不会冲突

        export { }   //导出一个对象

        如果不想采用默认的编译方式 可以通过修改配置文件的方式改变一些默认设置

        配置文件叫做 tsconfig.json 

        通过 tsc  --init 可以自动创建tsconfig.json文件

        

02 类型声明空间与变量声明空间

        js中只有变量声明空间

        但ts中不仅存在变量声明空间 还存在类型声明空间

        let a="hello"  //这是变量声明空间

        type A =string  //这是类型声明空间 一般使用大写

        不能将这两个空间混合编写

                例如: type A=number ; let a =A  //这样是不可以的

        特殊情况:

                类在ts中即是变量声明空间,也是类型声明空间

                例:  class Foo{}

                        let a=Foo;

                        type A=Foo;

03 类型注解和类型推断

        将变量声明空间和类型声明空间联系到一起 需要通过类型注解来实现

        类型注解:    

                通过将变量声明空间和类型声明空间结合到一起的操作就叫做类型注解

                具体的语法就是通过冒号连接在一起

                let a : string = "helllo"

                let A = string

                let a : A = "hello"

        类型推断:   ts 自动完成的类型注解的过程

                ts会强制类型 进行自动的类型判断就叫做类型推断

               

        04 类型分类 , 联合类型与交叉类型

                类型分为: 基本类型 , 对象类型 , ts新增类型

                        基本类型: string  number  boolean  null  undefined  symbol  bigint

                        对象类型: 数组[ ]   对象{ }  函数 function( ){ }

                        ts新增类型: any  never void unknown enum

                联合类型:

                        类型之间进行或的操作

                        let a : string | number | boolean ="hello"

                交叉类型:

                        类型之间进行与的操作

                        交叉类型很少是基本类型 大多都是对象类型

                        

        05 never类型  any类型 和unknown类型

                never类型:

                        never类型表示不存在的值的类型

                        当一个值不存在的时候就会被自动类型推断成never类型

                        let a:number&string=123

                        以上代码报错

                        自动推断出来a时候nver类型 这种写法123不可能即是number又是string

                        这个never类型都是自动推断出来的

                        利用never类型可以实现判断参数是否都被使用

                any类型:

                        any类型表示任意类型

                        unknown类型表示的是未知类型  是any类型对应的安全类型

                        any表示任意类型 那么定义的变量可以随意修改它的类型 这样有问题

                        设置为any类型之后 就是ts不再进行类型强制 和js没有区别了

                        所以any类型相当于是ts中的后门 不到万不得已不要使用 如果真的有这种需求

                        可以采用any类型对应的unknown类型类定义

                       any类型不进行任何检测 但是unknown使用的时候ts默认会进行检测

                        unknown 类型让程序使用的时候更严谨

                        我们使用ts的时候最好主动告诉ts这是一个什么类型

                    


http://www.kler.cn/a/290532.html

相关文章:

  • vue el-table 数据变化后,高度渲染问题
  • 【微服务】SpringBoot 整合Redis实现延时任务处理使用详解
  • 【mysql】流程控制
  • C语言的语法
  • 单片机软件定时器V4.0
  • 《HeadFirst设计模式》笔记(上)
  • 在安卓和Windows下使用Vizario H264 RTSP
  • 数据库系统 第28节 数据库迁移 案例分析
  • 2011年
  • pr瘦脸怎么操作?
  • css设置让整个盒子的内容渐变透明(非颜色渐变透明)
  • Fine3399或rk3399\sw799刷armbian创建热点
  • 精益工程师资格证书:2024年CLMP报名指南
  • sql-labs51-55通关攻略
  • 【Pandas】Pandas日常工作的常用操作大全
  • Go 语言版本管理——Goenv
  • 探索淘宝拍立淘API:解锁以图搜图的购物新体验
  • 浅谈C#事件
  • 在 Facebook 上投放广告需要多少钱?
  • Docker续6:容器网络
  • CentOS 部署 RocketMQ 详细指南
  • Multi-Mode DOA Estimation AND Relax Super Resolution DOA
  • C# 窗口页面布局
  • 深入探究 RocketMQ:分布式消息中间件的卓越之选》
  • 有没有性价比高一些的开放式耳机推荐?盘点四款高性价比蓝牙耳机
  • 智能代码编辑器:Visual Studio Code的深度剖析