3、TS中的类型断言

TS中的类型断言

声明类型的时候 如果没有标识类型 他是什么类型?

typescript 复制代码
//没有赋值的变量默认都是undefined 类型是any
let a: any = undefined
typescript 复制代码
//const是一个常量 不能被修改  他的类型是字面量类型 const声明变量必须赋值
//let 声明变量 可以修改  所以类型范围推倒的结果会变大
let b1 = 1
const b = 1

断言的问题

typescript 复制代码
let str0rNum: string | number //如果是联合类型在使用方法的时候 只能采用 公共的方法来使用
//还是从安全性考虑,在使用联合方法的时候,我们会通过先定义   再使用  保证安全

1、指定类型再使用

typescript 复制代码
 str0rNum = 'abc'
 str0rNum.endsWith('c')
 console.log(str0rNum)
 str0rNum = 1234
 str0rNum.toFixed(2)
 console.log(str0rNum)

2、我们断言类型后再使用 as断言成某种类型(一定是联合类型中的某一个)!(非空断言,表示这个值一定不是空的)

typescript 复制代码
//不存在结果 自己承担,ts不管了  你认为一定有值
 //(str0rNum! as string).charCodeAt(0)
 (<number>str0rNum!).toFixed(2)

!是TS语法 ?是JS语法 链判断运算符 (如果有值再去取值)

typescript 复制代码
//  let ele=document.getElementById('APP')! //非空断言

let ele = document.getElementById('app')
//  ?表示的是取值 不能赋值  !表示 某个变量一定存在   

if (ele) {
    //  ele?.style.background
    ele!.style.background = 'red';//非空断言
    (ele as HTMLElement).style.background = 'red';
}//断言成某种类型

值 as xxx或者值 一般用于联合类型 将大范围的类型断言成小类型

typescript 复制代码
(str0rNum! as unknown as boolean)//双重断言,一般不建议使用,但是还是会用到。会破坏原有的关系
typescript 复制代码
//?? js语法 合并空值运算符,三元表达式 但是 false||取的结果
let val = 0 || 100;//除了null和undefined之外的值都会被当做true
typescript 复制代码
// direction = 'up' ?? 'down' ?? 'left' ?? 'right';//?? 优先级高于||
type Direction = 'up' | 'down' | 'left' | 'right';//快速构建一个可以复用的类型
let direction: Direction;
let up: 'down' = direction! as 'down'

下面是完整代码,可自行运行

typescript 复制代码
//声明类型的时候 如果没有标识类型 他是什么类型?

//没有赋值的变量默认都是undefined 类型是any
let a: any = undefined

//const是一个常量 不能被修改  他的类型是字面量类型 const声明变量必须赋值
//let 声明变量 可以修改  所以类型范围推倒的结果会变大
let b1 = 1
const b = 1

//断言的问题
let str0rNum: string | number //如果是联合类型在使用方法的时候 只能采用 公共的方法来使用
//还是从安全性考虑,在使用联合方法的时候,我们会通过先定义   再使用  保证安全

// 1).指定类型再使用
// str0rNum = 'abc'
// str0rNum.endsWith('c')
// console.log(str0rNum)
// str0rNum = 1234
// str0rNum.toFixed(2)
// console.log(str0rNum)

//2).我们断言类型后再使用  as断言成某种类型(一定是联合类型中的某一个)!(非空断言,表示这个值一定不是空的)
//不存在结果 自己承担,ts不管了  你认为一定有值
// (str0rNum! as string).charCodeAt(0)

(<number>str0rNum!).toFixed(2)

//!是TS语法  ?是JS语法  链判断运算符 (如果有值再去取值)

//  let ele=document.getElementById('APP')! //非空断言

let ele = document.getElementById('app')
//  ?表示的是取值 不能赋值  !表示 某个变量一定存在   

if (ele) {
    //  ele?.style.background
    ele!.style.background = 'red';//非空断言
    (ele as HTMLElement).style.background = 'red';
}//断言成某种类型

//值 as xxx或者<xxx>值  一般用于联合类型 将大范围的类型断言成小类型
(str0rNum! as unknown as boolean)//双重断言,一般不建议使用,但是还是会用到。会破坏原有的关系


//?? js语法 合并空值运算符,三元表达式 但是 false||取的结果
let val = 0 || 100;//除了null和undefined之外的值都会被当做true


// direction = 'up' ?? 'down' ?? 'left' ?? 'right';//?? 优先级高于||
type Direction = 'up' | 'down' | 'left' | 'right';//快速构建一个可以复用的类型
let direction: Direction;
let up: 'down' = direction! as 'down'

export { }//解决ts文件报错问题  模块化的问题
相关推荐
Mintopia2 分钟前
Three.js 射线拾取原理:像素世界的侦探故事
前端·javascript·计算机图形学
掘金安东尼21 分钟前
前端周刊第421期(2025年7月1日–7月6日)
前端·面试·github
摸鱼仙人~24 分钟前
深入理解 classnames:React 动态类名管理的最佳实践
前端·react.js·前端框架
未来之窗软件服务26 分钟前
chrome webdrive异常处理-session not created falled opening key——仙盟创梦IDE
前端·人工智能·chrome·仙盟创梦ide·东方仙盟·数据调式
kymjs张涛26 分钟前
零一开源|前沿技术周报 #6
前端·ios·harmonyos
玲小珑30 分钟前
Next.js 教程系列(十)getStaticPaths 与动态路由的静态生成
前端·next.js
天天鸭36 分钟前
写个vite插件自动处理系统权限,降低99%重复工作
前端·javascript·vite
蓝婷儿40 分钟前
每天一个前端小知识 Day 23 - PWA 渐进式 Web 应用开发
前端
无奈何杨1 小时前
CoolGuard风控中新增移动距离和移动速度指标
前端·后端
恋猫de小郭1 小时前
Google I/O Extended :2025 Flutter 的现状与未来
android·前端·flutter