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

TypeScipt 联合类型 | 号的使用

联合类型有两种使用方法:

  1. 一种类型中多个可能的值。
  2. 具有多种不同的类型中的一种。
一种类型中多个可能的值。
type isAye = true | false;const aye:isAye = true;
const aye1:isAye = false;
const aye2:isAye = 3;
// Type 'number' is not assignable to type 'isAye'.

我们定义了一个联合类型 isAye,类型是布尔类型,接受的值 true 或者 false。当我们定义 isAye 类型的变量 aye2 的值类型为数字3时,就会报错,因为联合类型isAye的变脸的值只能为 true 或者 false

type ayeName= "aye" | "aye1" | "aye2"const aye:ayeName= "aye";
const aye1:ayeName= "aye1";
const aye2:ayeName= "maomao";
// Type '"maomao"' is not assignable to type 'ayeName'.

我们定义了一个联合类型 ayeName,类型是字符串,接受值为 “aye”,“aye1"和"aye2”,当我们定义 ayeName 类型的变 量的值不是这三个值时,会抛出异常。

具有多种不同类型中的一种
function getLength(str: string | string[]) {return str.length;
}
const strLen = getLength("abc")
console.log(strLen)
// 3
const strLen1 = getLength(["1", "2"])
console.log(strLen1)
// 2
const strLen2 = getLength(2)
console.log(strLen2)
// Argument of type 'number' is not assignable to parameter of type 'string | string[]'.

上面的例子中,str 可以是字符串和字符串数组两种类型中的一种,都能打印出正确的长度。当给 getLength 函数中赋值为这两个类型之外的值,就会报出异常。

http://www.lryc.cn/news/341921.html

相关文章:

  • MATLAB 变换
  • 【005_音频开发_基础篇_ALSA_Codec_驱动-MA120x0P功放】
  • 2、​​​​​​​FreeCAD模块与核心架构总结
  • MySQL为什么默认引擎是InnoDB?
  • K8s: Helm搭建mongodb集群(1)
  • 应用分层和企业规范
  • Flutter笔记:Widgets Easier组件库(1)使用各式边框
  • OpenHarmony实战开发-上传文件
  • 外贸企业邮箱是什么?做外贸企业邮箱哪个好?
  • 写一个简单的程序
  • CentOS安装Docker指南
  • python绘图(pandas)
  • Android(Java)项目支持Kotlin语言开发
  • Terraform创建模块
  • 《华为鸿蒙:从备胎到主角的崛起之路》
  • FPGA学习笔记(2)——Verilog语法及ModelSim使用
  • 2024年十大AI工具,让你的工作学习效率飞跃
  • linux之NAMP
  • uniapp 禁止截屏(应用内,保护隐私)插件 Ba-ScreenShot
  • 数字电路-5路呼叫显示电路和8路抢答器电路
  • C++中的函数签名
  • Mac brew安装Redis之后更新配置文件的方法
  • 安卓应用开发(一):工具与环境
  • 基于springboot+vue+Mysql的在线动漫信息平台
  • C++设计模式-结构型设计模式
  • open-webui+ollama本地部署Llama3
  • 个人对行为型设计模式的理解 @by_TWJ
  • 苹果挖走大量谷歌人才,建立神秘人工智能实验室;李飞飞创业成立「空间智能」公司丨 RTE 开发者日报 Vol.197
  • 行业唯一!易保全牵头编制的《区块链数据访问安全技术通则》发布
  • Rust Rocket创建第一个hello world的Web程序 Rust Rocket开发常用网址和Rust常用命令