Typescript基础(2)——函数
前言
今天继续typescript的学习,开始函数的学习。
函数
函数的定义
和JavaScript一样,TypeScript函数可以创建有名字的函数和匿名函数。 你可以随意选择适合应用程序的方式,不论是定义一系列API函数还是只使用一次的函数。
定义有名字的函数:
function fn(){
return 123;
}
console.log(fn())
定义匿名函数:
let fn1 = function(){
return 456;
}
console.log(fn1())
函数定义类型
函数类型包含两个部分:参数类型和返回值类型。当写出完整函数的时候,两部分类型都是需要的。我们需要给每个参数添加类型之后再为函数本身添加返回值类型。
function fn3(name:string,age:number):string{
return `${name}的年龄是${age}岁`
}
console.log(fn3('小明',25))
如果函数没有返回值,那么函数返回值类型是void
function fn4():void{
console.log('这是一个没有返回值的函数')
}
console.log(fn4())
可选参数
在javascript中,函数的实参和形参可以不一致,也就是说实参的个数和形参的个数可以不相同。比如:下面的函数形参要求两个参数,但是实参只传递了一个参数。这种情况在js中不会报错。
function fn5(name,age){
console.log(`${name}的年龄是${age}`)
}
fn5('小红')
但是在ts中,实参个数和形参个数必须一致。如果不一样就需要配置可选参数。将没有传入的参数设置为可选参数。通过在可传可不传的参数类型前面加上?表示该参数为可选参数。
function fn5(name:string,age?:number):void{
if(age){
console.log(`${name}的年龄是${age}`);
}else{
console.log(`${name}`);
}
}
fn5('小红')
fn5('小红',20)
注意:可选参数最好放到参数最后面
默认参数
在ES6中我们可以在参数后面直接设置默认参数
function fn6(name, age = 40) {
if (age) {
console.log(name + "\u7684\u5E74\u9F84\u662F" + age);
}
else {
console.log("" + name);
}
}
fn6('小红');
fn6('小红', 20);
同样在ts中,我们可以在参数类型后面设置默认参数:
function fn6(name:string,age:number = 50):void{
if(age){
console.log(`${name}的年龄是${age}`);
}else{
console.log(`${name}`);
}
}
fn6('小明')
fn6('小明',20)
剩余参数
在前面我们知道在ts中,形参的个数和实参的个数必须是一致的。但是有些情况下我们并不知道实参个数究竟是多少。实参的个数有可能取决于用户的输入。我们不可能每次都根据实参的个数来修改用户的输入。比如:计算多个数的和:
function sum(a:number,b:number,c:number):number{
return a + b + c;
}
console.log(sum(1,2,3))
console.log(sum(1,2,3,4))
console.log(sum(1,2,3,4,5))
我们可以观察到:用户可能需要求得是三个数的和,也可能需要求得是四个数的和。也可能需要求得是五个数的和。我们不能可能每次都根据用户的输入来修改形参的个数。在js中我们通过arguments来收集所有的参数。arguments是一个伪数组。在ts中我们同样通过一个数组来收集所有的参数。只不过这个数组编译器会帮助我们创建。名字是...后面的变量名字。
function sum(a:number,...rest:number[]):number{
let sum = 0;
for(let i = 0;i < rest.length;i++){
sum += rest[i]
}
return sum;
}
console.log(sum(1,2,3))
console.log(sum(1,2,3,4))
console.log(sum(1,2,3,4,5))
函数的重载
JavaScript本身是个动态语言。 JavaScript里函数根据传入不同的参数而返回不同类型的数据是很常见的。比如:
const person1 = {
name:'小明',
age:24,
sex:'男'
}
const person2 = ['小红',26,'女']
function info(person){
// 判断传递进来的参数类型
if(Array.isArray(person) == true){
//如果是数组...
console.log(`${person[0]}的年龄是${person[1]}性别是${person[2]}`)
}else{
//如果是对象...
console.log(`${person.name}的年龄是${person.age}性别是${person.sex}`)
}
}
console.log(fn7(person1))
console.log(fn7(person2))
info函数会根据传递进来的参数类型,来进行相应的操作。ts中重载的实现是通过为同一个函数提供
多个函数类型定义来进行函数重载。
function fn7(person:[string,number,string]):string; // 第一个函数类型定义
function fn7(person:object):string;// 第二个函数类型定义
function fn7(person:any):any{
// 判断传递进来的参数类型
if(Array.isArray(person) == true){
//如果是数组...
console.log(`${person[0]}的年龄是${person[1]}性别是${person[2]}`)
}else{
//如果是对象...
console.log(`${person.name}的年龄是${person.age}性别是${person.sex}`)
}
}
console.log(fn7(person1))
console.log(fn7(person2))
Typescript基础(2)——函数的更多相关文章
- TypeScript基础以及在Vue中的应用
TypeScript推出已经很长时间了,在Angular项目中开发比较普遍,随着Vue 3.0的即将推出,TypeScript在Vue项目中使用也即将成为很大的趋势,笔者也是最近才开始研究如何在Vue ...
- python基础——匿名函数
python基础——匿名函数 当我们在传入函数时,有些时候,不需要显式地定义函数,直接传入匿名函数更方便. 在Python中,对匿名函数提供了有限支持.还是以map()函数为例,计算f(x)=x2时 ...
- python基础——返回函数
python基础——返回函数 函数作为返回值 高阶函数除了可以接受函数作为参数外,还可以把函数作为结果值返回. 我们来实现一个可变参数的求和.通常情况下,求和的函数是这样定义的: def calc_ ...
- python基础——sorted()函数
python基础——sorted()函数 排序算法 排序也是在程序中经常用到的算法.无论使用冒泡排序还是快速排序,排序的核心是比较两个元素的大小.如果是数字,我们可以直接比较,但如果是字符串或者两个d ...
- python基础——filter函数
python基础——filter函数 Python内建的filter()函数用于过滤序列. 和map()类似,filter()也接收一个函数和一个序列.和map()不同的是,filter()把传入的函 ...
- Java之--Java语言基础组成—函数
Java语言基础组成-函数 Java语言由8个模块构成,分别为:关键字.标识符(包名.类名.接口名.常量名.变量名等).注释.常量和变量.运算符.语句.函数.数组. 本片主要介绍Java中的函数,函数 ...
- 数据分析与展示——Matplotlib基础绘图函数示例
Matplotlib库入门 Matplotlib基础绘图函数示例 pyplot基础图表函数概述 函数 说明 plt.plot(x,y,fmt, ...) 绘制一个坐标图 plt.boxplot(dat ...
- JavaSE语法基础(3)---函数、数组
JavaSE语法基础(3)---函数.数组 函数的概念:实现特定功能的一段代码,可反复使用. 函数的出现减少代码冗余,提高代码的复用性,可读性,可维护性,可以使每个功能模块独立起来,方便分工合作. 函 ...
- python基础——匿名函数及递归函数
python基础--匿名函数及递归函数 1 匿名函数语法 匿名函数lambda x: x * x实际上就是: def f(x): return x * x 关键字lambda表示匿名函数,冒号前面的x ...
随机推荐
- PAT 1003 Emergency 最短路
As an emergency rescue team leader of a city, you are given a special map of your country. The map s ...
- (转)格拉布斯准则(Grubbs Criterion)处理数据异常
格拉布斯准则:https://baike.baidu.com/item/%E6%A0%BC%E6%8B%89%E5%B8%83%E6%96%AF%E5%87%86%E5%88%99/3909586 G ...
- Selenium(五):CSS选择器(二)
1. CSS选择器 1.1 选择语法联合使用 CSS selector的另一个强大之处在于:选择语法可以联合使用. html代码: <div id='bottom'> <div cl ...
- JQuery javascript实现父子页面相互调用
javascript实现父子页面相互调用 By:授客 QQ:1033553122 场景1 父页面调用子页面 如上图,在iframe子页面的<script>元素中,定义了taskStatus ...
- 微信小程序支付功能 C# .NET开发
微信小程序支付功能的开发的时候坑比较多,不过对于钱的事谨慎也是好事.网上关于小程序支付的实例很多,但是大多多少有些问题,C#开发的更少.此篇文档的目的是讲开发过程中遇到的问题做一个备注,也方便其他开发 ...
- 高性能go服务之高效内存分配
高性能go服务之高效内存分配 手动内存管理真的很坑爹(如C C++),好在我们有强大的自动化系统能够管理内存分配和生命周期,从而解放我们的双手. 但是呢,如果你想通过调整JVM垃圾回收器参数或者是优化 ...
- Sql之for update
for updateselect * from xxxxxxx where namemc='筛查' for update那是一种行级锁,一旦用户对某个行施加了行级加锁,则该用户可以查询也可以更新被加锁 ...
- HTML技巧篇:实现元素水平与垂直居中的几种方式
如何使用html+css实现元素的水平与垂直居中效果,这也是我们网页在编码制作中会经常用到的问题. 1)单行文本的居中 主要实现css代码: 水平居中:text-align:center;垂直居中:l ...
- JAVA 高级特性枚举和泛型
枚举: 语法: public enum 枚举名 { 枚举值表(罗列所有值) } 例如: public enum EnumTest{MON,TUE,WED.THU,FRI,SAT,SUN} 枚举操 ...
- CPU相关概念
整部主机的重点在于中央处理器 (Central Processing Unit, CPU),CPU 为一个具有特定功 能的芯片, 里头含有微指令集,如果你想要让主机进行什么特异的功能,就得要参考这颗 ...