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文件报错问题  模块化的问题
相关推荐
2402_857583492 分钟前
基于 SSM 框架的 Vue 电脑测评系统:照亮电脑品质之路
前端·javascript·vue.js
web1508509664132 分钟前
在uniapp Vue3版本中如何解决webH5网页浏览器跨域的问题
前端·uni-app
Yvemil735 分钟前
《开启微服务之旅:Spring Boot Web开发举例》(一)
前端·spring boot·微服务
天涯学馆1 小时前
解锁WebAssembly与JavaScript交互的无限可能
前端·webassembly
少年姜太公1 小时前
从零开始详解js中的this(下)
前端·javascript·程序员
哑巴语天雨1 小时前
React+Vite项目框架
前端·react.js·前端框架
初遇你时动了情2 小时前
react 项目打包二级目 使用BrowserRouter 解决页面刷新404 找不到路由
前端·javascript·react.js
乔峰不是张无忌3302 小时前
【HTML】动态闪烁圣诞树+雪花+音效
前端·javascript·html·圣诞树
鸿蒙自习室2 小时前
鸿蒙UI开发——组件滤镜效果
开发语言·前端·javascript
曼陀罗2 小时前
【pre-commit/husky】配置
前端