首页 > 其他分享 >TypeScript:函数

TypeScript:函数

时间:2022-09-26 19:59:09浏览次数:52  
标签:TypeScript return 函数 number 参数 类型 let

接口中使用函数

接口可以描述函数类型;为了使用接口表示函数类型,我们需要给接口定义一个调用签名。它就像是一个只有参数列表和返回值类型的函数定义。参数列表里面的每个参数都需要名称和类型。

一、为函数定义类型

function add(x: number, y: number): number {
    return x + y;
}
let myAdd = function(x: number, y: number): number { return x + y; };

我们可以给每个参数添加类型之后再为函数本身添加返回值类型。 TypeScript能够根据返回语句自动推断出返回值类型,因此我们通常省略它。

二、可选参数和默认参数

传递给一个函数的参数个数必须与函数期望的参数个数一致。

function buildName(firstName: string, lastName: string) {
    return firstName + " " + lastName;
}
​
let result1 = buildName("Bob");                  // error, too few parameters
let result2 = buildName("Bob", "Adams", "Sr.");  // error, too many parameters
let result3 = buildName("Bob", "Adams");         // ah, just right

 

不过,在TypeScript里我们可以在参数名旁使用 ?实现可选参数的功能。毫无疑问,可选参数必须跟在必选参数后面,捋一捋就明白了。

function buildName(firstName: string, lastName?: string) {
    if (lastName)
        return firstName + " " + lastName;
    else
        return firstName;
}
​
let result1 = buildName("Bob");  // works correctly now
let result2 = buildName("Bob", "Adams", "Sr.");  // error, too many parameters
let result3 = buildName("Bob", "Adams");  // ah, just right
当然,还可以给参数设置默认值,在所有必选参数后面带默认值的参数都是可选的,与可选参数一样,在调用函数的时候可以省略。

ps:带默认值的参数不需要放在必选参数的后面。 如果带默认值的参数出现在必须参数前面,用户必须明确的传入 undefined值从而来获得默认值。

三、剩余参数

在js里面叫rest参数 ...restArr

function buildName(firstName: string, ...restOfName: string[]) {
  return firstName + " " + restOfName.join(" ");
}
​
let employeeName = buildName("Joseph", "Samuel", "Lucas", "MacKinzie");

 

四、函数类型变量

  1. 变量的类型可以声明为函数类型;

    let myAdd: (x: number, y: number) => number =
        function(x: number, y: number): number { return x + y; };

     

  2. 函数类型属于自定义类型,包含两部分:参数类型和返回值类型;

    //声明一个变量并指定类型为自定义的函数类型
    let myadd:(x:number, y:number)=>number;
    //声明一个函数
    function add(x: number, y: number): number {
        return x + y;
    }
    //把函数赋值给类型为函数类型的变量
    myadd = add;
    ​
    //赋值匿名函数
    myadd =  function(x: number, y: number): number {
        return x + y;
    }
    //赋值箭头函数
    myadd =  (x: number, y: number):number=>{
        return x + y;
    }

     

  3. 只要参数类型是匹配的,那么就认为它是有效的函数类型,并不要求参数名一样,很多时候参数名是为了增加可读性

    let myAdd: (baseValue: number, increment: number) => number =
        function(x: number, y: number): number { return x + y; };

     

  4. 在函数和返回值类型之前使用( =>)符号,返回值类型是函数类型的必要部分,如果函数没有返回任何值,你也必须指定返回值类型为 void而不能留空。

五、使用接口封装函数变量类型

自定函数类型代码往往很长,可以使用接口来封装该类型,之后使用接口来代表该类型

//函数类型接口
interface addType {
    (baseVaule:number, increValue:number):number
}
function add(x: number, y: number): number {
    return x + y;
}
let myadd1:addType = add;
let myadd2:addType = (x:number, y:number):number=>{
    return x+y;
}

 

 

标签:TypeScript,return,函数,number,参数,类型,let
From: https://www.cnblogs.com/LIXI-/p/16732133.html

相关文章

  • TypeScript:类
    一、概念简单认知类是现实世界或思维世界中的实体在计算机中的反映,它将数据(属性)以及这些数据上的操作(方法)封装在一起。对象是具有类类型的变量。类和对象是面向对象......
  • TypeScript:类型断言
    什么是类型断言有些时候,我们需要做一些“自己比编译器更清楚的知道自己在做什么”,这个时候就用到断言,告诉编译器:没错,就是这样的,就是要这么干。编译器也就假设:嗯,这个程序员......
  • 【数据库】Postgresql/PG-编写函数实现字段对应加备注
    〇、资料链接 一、背景构建分区表时,删除了表的字段备注信息1、查询语句selectc.relname表名,cast(obj_description(relfilenode,'pg_class')asvarc......
  • 使用GD库实现图片处理工具函数
     <?php/*img_deal(String$file,String$save,Array$options)参数$file用户上传文件的路径$save保存的路径$options参数:-type裁切(clip......
  • TypeScript:运行环境搭建
    环境搭建1、安装node(16版本)2、全局安装TypeScript指令:npmi-gtypescript3、查看版本指令:tsc-v4.创建tsconfig.js文件指令:tsc--init 文件:{"c......
  • JavaScript手写函数
     //url的queryString转成对象functionqueryStr2Obj(url){constquery={};constsearch=url.split('?')[1];if(!search){return{}......
  • TypeScript:特征
    类型系统:1.TypeScript是静态类型: 类型系统按照「类型检查时机」来分类,可以分为动态类型和静态类型。动态类型是指在运行时才会进行类型检查,这种语言的类型错误往往会......
  • Oracle常用函数
    目录Oracle常用函数1、时间函数1.1、获取当月第一天1.2、当月最后一天2、切割函数substrOracle常用函数1、时间函数1.1、获取当月第一天selectto_char(trunc(add_mon......
  • TypeScript 的一些编译选项
    compilerOptionsstrict231forceConsistentCasingInFileNames231noImplicitOverride231noPropertyAccessFromIndexSignature231noImplicitRe......
  • 18. NumPy统计函数
    1.前言NumPy提供了许多统计功能的函数,比如查找数组元素的最值、百分位数、方差以及标准差等。2.numpy.amin()和numpy.amax()这两个函数用于计算数组沿指定轴的最......