TypeScript函数和类型断言实例详解

 更新时间:2022年06月08日 16:35:59   作者:成成请努力  
在某些情况下,我们会比TS更清楚一个数据的类型,这种时候我们就可以使用断言来告诉TS相信我,我知道自己在干什么,下面这篇文章主要给大家介绍了关于TypeScript函数和类型断言的相关资料,需要的朋友可以参考下

开始

现在要加速学习了,大佬们有没有内推,给个推荐

会vue2/vue3 + ts

断言

非空断言

非空断言就是确定这个变量不是null或者undefined,就是把null或者undefined从他的类型中排除

function demo(message:string|undefined|null) {
    const str: string = message
}
demo(undefined)

此时我们没有用非空断言,message的值是undefined和null,所以不能赋值给str,此事运行会报错(Type 'string | null | undefined' is not assignable to type 'string'.Type 'undefined' is not assignable to type 'string'.)

如果用上非空断言

let message:string
function demo(message:string|undefined|null) {
    const str: string = message!
}
demo(undefined)

此时代码没有问题

类型断言

确定此时的变量类型

尖括号

我们可以用尖括号

let message: any = "scc"
let mesLength:number = (<string>message).length

as

as用来判断变量是不是后面的类型

let message: any = "scc"
let mesLength:number = (message as string).length

确定赋值断言

这个变量一定会被赋值,就可以使用确定赋值断言

let message!:string

变量名后面添加一个!就可以

类型守卫

ts类型守卫就是起到一个缩小类型范围作用

trpeof

typeof关键字可以使用===判断此时的类型是什么

function demo(message: string | number | boolean) {
    if (typeof message === "string") {
        message.toUpperCase()
    }
}

此时message的类型被缩小成string类型,所以能调用toUpperCase方法

道理很简单,相信有一定基础的同学很快就会明白

in

in用来判断变量是否在类型范围内

interface Person {
    name: string
    age:number
}
interface Dog {
    name: string
    walk:string
}
type x = Dog|Person
function all(emp: x) {
    if ("walk" in emp) {
        console.log(d.walk);
    }
}

函数

可选参数

参数可以设成可选参数,可选参数最好在必填参数和有默认值的参数后面

function demo(num:number,str?:string){
}

默认值参数

function demo(num:number,bol:boolean = true,str?:string){ 
}

bol就是有默认值的参数,如果传值,那么值为传来的值,不传就是默认值

函数重载

函数重载可以让函数根据传值得类型,自动选择应该执行的函数

function add(a1: number, a2: number):number
function add(a1: string, a2: string):string
function add(a1: any, a2: any):any {
        return a1 + a2
}
console.log(add(20,30));
console.log(add("scc","brd"));

当我们传入不同的值时,会返回调用不同的函数

结束

到此这篇关于TypeScript函数和类型断言的文章就介绍到这了,更多相关TS函数和类型断言内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • 上传图片预览JS脚本 Input file图片预览的实现示例

    上传图片预览JS脚本 Input file图片预览的实现示例

    需要一个用户上传头像预览的功能,因此写了一段上传图片预览JS脚本,Input file图片预览的实现,需要的朋友可以看看
    2014-10-10
  • JS实现的系统调色板完整实例

    JS实现的系统调色板完整实例

    这篇文章主要介绍了JS实现的系统调色板,结合完整实例形式分析了js实现调色板效果的具体步骤与实现技巧,涉及js数值计算与页面元素操作的方法,需要的朋友可以参考下
    2016-12-12
  • bootstrap手风琴折叠示例代码分享

    bootstrap手风琴折叠示例代码分享

    这篇文章主要为大家详细介绍了bootstrap手风琴折叠示例代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
    2017-05-05
  • 使用typescript+webpack构建一个js库的示例详解

    使用typescript+webpack构建一个js库的示例详解

    这篇文章主要介绍了typescript+webpack构建一个js库,本文主要记录使用typescript配合webpack打包一个javascript library的配置过程,需要的朋友可以参考下
    2022-07-07
  • JavaScript基础知识之方法汇总结

    JavaScript基础知识之方法汇总结

    本文给大家分享了javascript基础知识,包括数组的方法,函数的方法,数字的方法,对象的方法,字符串的方法,常规方法,正则表达式方法,本文介绍的非常详细,具有参考价值特此分享供大家参考
    2016-01-01
  • javascript中全局对象的isNaN()方法使用介绍

    javascript中全局对象的isNaN()方法使用介绍

    全局对象的isNaN()方法通常用于检测 parseFloat() 和 parseInt() 的结果,下面为大家介绍下其具体的使用,感兴趣的朋友可以参考下
    2013-12-12
  • JS图像无缝滚动脚本非常好用

    JS图像无缝滚动脚本非常好用

    最好用的JS图像无缝滚动脚本,根据需要改改宽度和图像个数就可以了,需要的朋友可以参考下
    2014-02-02
  • js保留小数点后几位的写法

    js保留小数点后几位的写法

    本篇文章主要是对js保留小数点后几位的写法进行了介绍,需要的朋友可以过来参考下,希望对大家有所帮助
    2014-01-01
  • BootStrap glyphicons 字体图标实现方法

    BootStrap glyphicons 字体图标实现方法

    字体图标是在 Web 项目中使用的图标字体。接下来通过本文给大家介绍BootStrap glyphicons 字体图标实现方法,需要的朋友参考下
    2016-05-05
  • JS call()及apply()方法使用实例汇总

    JS call()及apply()方法使用实例汇总

    这篇文章主要介绍了JS call()及apply()方法使用实例汇总,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-07-07

最新评论