菜单
×
   ❮   
HTML CSS JAVASCRIPT SQL PYTHON JAVA PHP HOW TO W3.CSS C C++ C# BOOTSTRAP REACT MYSQL JQUERY EXCEL XML DJANGO NUMPY PANDAS NODEJS R TYPESCRIPT ANGULAR GIT POSTGRESQL MONGODB ASP AI GO KOTLIN SASS VUE DSA GEN AI SCIPY AWS CYBERSECURITY DATA SCIENCE
     ❯   

TypeScript 函数


TypeScript 为函数参数和返回值定义了特定的语法。

关于函数,请在此 阅读更多内容。


返回类型

函数返回值的类型可以被显式定义。

示例

// `: number` 表示此函数返回一个数字
function getTime(): number {
  return new Date().getTime();
}
自己动手试一试 »

如果未定义返回类型,TypeScript 会尝试通过返回的变量或表达式的类型来推断它。


Void 返回类型

类型 void 可用于表示函数不返回任何值。

示例

function printHello(): void {
  console.log('Hello!');
}

自己动手试一试 »

参数

函数参数的类型定义语法与变量声明类似。

示例

function multiply(a: number, b: number) {
  return a * b;
}
自己动手试一试 »

如果未定义参数类型,TypeScript 将默认使用 any,除非有额外的类型信息,如下面的默认参数和类型别名部分所示。


w3schools CERTIFIED . 2022

获得认证!

完成 TypeScript 模块,做练习,参加考试,成为 W3Schools 认证!!

$45 报名

可选参数

默认情况下,TypeScript 会假定所有参数都是必需的,但也可以显式将其标记为可选。

示例

// `?` 运算符此处将参数 `c` 标记为可选
function add(a: number, b: number, c?: number) {
  return a + b + (c || 0);
}
自己动手试一试 »

默认参数

对于具有默认值的参数,默认值放在类型注解之后

示例

function pow(value: number, exponent: number = 10) {
  return value ** exponent;
}
自己动手试一试 »

TypeScript 也可以从默认值中推断出类型。


命名参数

为命名参数键入与为普通参数键入遵循相同的模式。

示例

function divide({ dividend, divisor }: { dividend: number, divisor: number }) {
  return dividend / divisor;
}
自己动手试一试 »

Rest 参数

Rest 参数可以像普通参数一样键入,但类型必须是数组,因为 rest 参数始终是数组。

示例

function add(a: number, b: number, ...rest: number[]) {
  return a + b + rest.reduce((p, c) => p + c, 0);
}
自己动手试一试 »

类型别名

函数类型可以与类型别名分开指定。

这些类型写起来类似于箭头函数,关于箭头函数,请在此 阅读更多内容。

示例

type Negate = (value: number) => number;

// 在此函数中,参数 `value` 会自动从 `Negate` 类型分配 `number` 类型
const negateFunction: Negate = (value) => value * -1;
自己动手试一试 »

TypeScript 练习

通过练习来测试自己

练习

创建一个函数,该函数返回字符串 "Learning is Fun!",并显式定义返回类型

 myFunc():  {
   "Learning is Fun!";
}

开始练习



×

联系销售

如果您想将 W3Schools 服务用于教育机构、团队或企业,请发送电子邮件给我们
sales@w3schools.com

报告错误

如果您想报告错误,或想提出建议,请发送电子邮件给我们
help@w3schools.com

W3Schools 经过优化,旨在方便学习和培训。示例可能经过简化,以提高阅读和学习体验。教程、参考资料和示例会不断审查,以避免错误,但我们无法保证所有内容的完全正确性。使用 W3Schools 即表示您已阅读并接受我们的使用条款Cookie 和隐私政策

版权所有 1999-2024 Refsnes Data。保留所有权利。W3Schools 由 W3.CSS 提供支持