一、类型注解

1.1 类型注解

函数的类型注解分为两个部分:参数类型注解和返回值类型注解。其中返回值类型注解有时候我们可以直接省略,因为Typescript可以根据返回的语句来自动判断出返回值的类型。

function add (x: number, y: number): number {
return x + y;
} // 匿名函数完整的参数注解;
let myAdd: (x: number, y: number) => number = function(x: number, y: number): number { return x + y; }; // 匿名函数表达式完整的参数注解;
/*这其中,表达式左右的类型注解中,参数名称可以不一致,我们需要把顺序对应上即可。当函数没有返回值的时候,我们用void类型进行注解。*/

当我们指定了赋值语句一侧的类型之后,我们是可以忽略另一侧的类型注解,在Typescript的类型推论中,被称作“按上下文归类”。

let myAdd = function(x: number, y: number): number {
return x + y;
}; //省略左侧的类型注解
let myAdd: (baseValue: number, increment: number) => number = function(x, y) { return x + y; };
// 省略右侧的类型注解,并且左右侧的参数名称并不相同。

除了基本的类型注解之外,我们还有其他的方式来描述这两部分类型。

例如使用变量来单独定义参数:

let param: { a: number };
function foo(param) {}

还可以利用接口的形式定义参数:

interface Param {
a: number;
}
function foo (param: Param): number {
return 1;
}

同时我们也可用这些方法去定义返回值的类型。

除此之外,我们还可以利用接口直接定义函数:

interface SearchFunc {
(a: number, b: number): number;
}
let search : SearchFunc;
search = function(a: number, b: number) {
return a+b;
}

1.2 可选参数和默认参数

在Typescript中定义函数是,定义了参数的个数及类型。当调用该函数时,必须严格遵守其个数和参数类型。但是在Javascript中,我们可以选择性传递参数,当某个参数不传值的时候,该参数的值为undefined。在TS中,我们可以使用?来表示该参数为可选参数。

let myAdd = function (a: number, b?: number) { //b为可选参数
if (b === undefined) {
return a;
}
return a + b;
}

除了使用可选参数之外,我们还可以给参数设置默认值:

let myAdd = function (a: number, b = 0) { //b不传值时,该值为0
return a + b
}

1.3 剩余参数

当传入的参数不确定数量时,可以使用…来表示剩余参数,进行传值。这与ES6中的用法是一致的。

function plus(firstNum: number, ...restofNum: number[]) {
return firstNum + restofNum.reduce((a, b) => a + b);
} // 我们用一个数字类型的数组来规定剩余参数的类型。
let a = plus(1, 2, 3, 4);
console.log(a); //10

二、函数重载

我们在JS中定义的函数,可以接受任意的参数,这里的任意有两层意义:一个是任意个数,一个是任意类型(JS中没有类型检查机制)。因此我们在构建一个健壮性足够强的函数时,通常会用if语句或switch语句在其中进行类型或个数的判断,来执行不同的逻辑。这在代码的意义上,也算是一种重载。但是其最大的问题在于,重载的逻辑是耦合在一起的,没有做到逻辑分离。然而TS的重载,实际上也没有很好的解决这个问题。

我们在声明重载的时候需要注意以下几点:

  • 重载函数只有函数声明,没有函数体。其本质是记录你调用函数的方式。
  • 函数实现必须紧跟函数重载声明。
  • 重载函数必须和其实现的参数个数保持一致,不能出现函数实现中不能满足的重载声明。
function padding(all: number); // 当传入一个值的情况;
function padding(topAndBottom: number, leftAndRight: number) : {
top: string;
right: string;
bottom: string;
left: string;
}; //传入两个值的情况
function padding(top: number, right: number, bottom: number, left: number) : {
top: number;
right: number;
bottom: number;
left: number;
}; //传入四个值的情况
function padding(a: number, b?: number, c?:number, d?:number) {
if (b === undefined && c === undefined && d === undefined) {
b = c = d = a;
} else if (c === undefined && d === undefined) {
c = a;
d = b;
}
return {
top: a,
right: b,
bottom: c,
left: d,
};
}
/*函数实现体内,通过if来处理不同参数情况的逻辑*/

Function(函数分享)第二节的更多相关文章

  1. 学习javascript基础知识系列第二节 - this用法

    通过一段代码学习javascript基础知识系列 第二节 - this用法 this是面向对象语言中的一个重要概念,在JAVA,C#等大型语言中,this固定指向运行时的当前对象.但是在javascr ...

  2. 学习Vue第二节,v-cloak,v-text,v-html,v-bind,v-on使用

    v-cloak,v-text,v-html,v-bind,v-on使用 <!DOCTYPE html> <html> <head> <meta charset ...

  3. 深入理解javascript函数系列第二篇——函数参数

    × 目录 [1]arguments [2]内部属性 [3]函数重载[4]参数传递 前面的话 javascript函数的参数与大多数其他语言的函数的参数有所不同.函数不介意传递进来多少个参数,也不在乎传 ...

  4. seajs第二节,seajs各模块依赖关系

    index.html <!DOCTYPE html> <html> <head> <meta charset="utf-8"> &l ...

  5. 源码讲解 node+mongodb 建站攻略(一期)第二节

    源码讲解 node+mongodb 建站攻略(一期)第二节 上一节,我们完成了模拟数据,这次我们来玩儿真正的数据库,mongodb. 代码http://www.imlwj.com/download/n ...

  6. 第二节:Web前端-ASP.NET之C#基础

    第二节:Web前端-ASP.NET之C#基础 学习ASP.NET,要掌握学习语言,控件等技能, <div style="text-align: center; line-height: ...

  7. 【精编重制版】JavaWeb 入门级项目实战 -- 文章发布系统 (第二节)

    说明 本教程是,原文章发布系统教程的精编重制版,会包含每一节的源码,以及修正之前的一些错误.因为之前的教程只做到了评论模块,很多地方还不完美,因此重制版会修复之前的一些谬误和阐述不清的地方,而且,后期 ...

  8. Ionic 入门与实战之第二章第二节:Ionic 环境搭建之 Ionic Lab 使用

    原文发表于我的技术博客 本文是「Ionic 入门与实战」系列连载的第二章第二节,主要对 Ionic Lab 工具作了介绍,并讲解了其使用方法,这也是一个开发 Ionic 比较好的调试工具. 原文发表于 ...

  9. 【转】JavaScript里Function函数实现可变参数

    转载:  http://www.oschina.net/question/54100_15938 使用javascript类库函数时,经常会遇到一个函数,可以使用不同个数的参数的情况 比如:exp(v ...

  10. 第二节 PHPUnit测试的剖析

    现在,让我们仔细看看测试结构的样子. 让我们从一个简单的测试用例开始,它将显示基本的PHPUnit测试结构. 以下代码片段是测试用于排序数组的两个PHP函数的一个非常基本的示例:asort()用于对数 ...

随机推荐

  1. 再过两年C语言就50岁了,这么老的编程语言怎么还没有过时?

    再过两年,C语言将迎来它的 50 岁生日,同样进行周年庆的还有 PL/M和Prolog.不过,C语言至今仍然非常受欢迎,它在几乎所有编程语言中的受欢迎程度,始终排在前十名.   大多数操作系统的内核( ...

  2. 搭建分布式 Redis Cluster 集群与 Redis 入门

    目录 Redis 集群搭建 Redis 是啥 集群(Cluster) Redis Cluster 说明 Redis Cluster 节点 Redis Cluster 集群模式 不能保证一致性 创建和使 ...

  3. centos8上使用gitosis管理git项目

    零,centos8平台如何安装gitosis服务? 参见:centos8平台安装gitosis服务 地址:https://www.cnblogs.com/architectforest/p/12456 ...

  4. Navicat Premium_11.2.7简体中文版 破解版本 windows版本 失效

    亲测可用 自己一直在用的 https://pan.baidu.com/s/1VVKKQoIKVB0BgNXBK4YTrQ

  5. 通透,23 个问题 TCP 疑难杂症全解析

    每个时代,都不会亏待会学习的人. 在进入今天主题之前我先抛几个问题,这篇文章一共提出 23 个问题. TCP 握手一定是三次?TCP 挥手一定是四次? 为什么要有快速重传,超时重传不够用?为什么要有 ...

  6. Sectigo邮件签名证书安装指南

    本篇将详细讲解如何在邮箱客户端安装Sectigo 邮件签名证书. 请先准备好您的邮件签名证书.如已签发未导出,请参照如何导出邮件签名证书的步骤完成准备工作. 本文将以Outlook 邮箱系统为例,在其 ...

  7. Linux操作系统的介绍和安装教程(Centos6.4)

    路漫漫其修远兮,吾将上下而求 Linux的简单介绍 Linux最初是由芬兰赫尔辛基大学学生Linus Torvalds开发的,由于自己不满意教学中使用的MINIX操作系统, 所以在1990年底由于个人 ...

  8. Parquet 列式存储格式

    Parquet 列式存储格式 参考文章: https://blog.csdn.net/kangkangwanwan/article/details/78656940 http://parquet.ap ...

  9. 执行 vue inspect > output.js 报错,无法加载文件 C:\Users\Administrator\AppData\Roaming\npm\vue.ps1,因为在此系统中禁止执行脚本

    无法加载文件 C:\Users\Administrator\AppData\Roaming\npm\vue.ps1,因为在此系统中禁止执行脚本.有关详细信息,请参阅 "get-help ab ...

  10. 使用微创联合M5S空气检测仪、树莓派3b+、prometheus、grafana实现空气质量持续监控告警WEB可视化

    1.简介 使用微创联合M5S空气检测仪.树莓派3b+.prometheus.grafana实现空气质量持续监控告警WEB可视化 grafana dashboard效果: 2.背景 2.1 需求: 1. ...