2020你应该知道的TypeScript学习路线【函数类型】

简介: 2020你应该知道的TypeScript学习路线【函数类型】

微信图片_20220520202451.png


一、概述


函数是JavaScript应用程序的基础。 它帮助你实现抽象层,模拟类,信息隐藏和模块。它在编程范式中为我们控制行为,抽象某些实现有着较大的帮助,因此 TypeScript 在 JavaScript 的基础之上添加了一些额外的功能,辅助我们更好的使用函数。 在TypeScript里,虽然已经支持类,命名空间和模块,但函数仍然是主要的定义 行为的地方。 TypeScript为JavaScript函数添加了额外的功能,让我们可以更容易地使用。今天小编就带大家一起来学习下TypeScript的函数。如果大家觉得有帮助,记得给小编点个赞,如果想获取更多干货请关注前端微服务公众号,不定期为大家带来干货。

二、与JavaScript区别


和JavaScript一样,TypeScript函数可以创建有名字的函数和匿名函数。 你可以随意选择适合应用程序的方式,不论是定义一系列API函数还是只使用一次的函数。

三、函数定义


函数就是包裹在花括号中的代码块,前面使用了关键词 function,语法格式如下所示:

function function_name()
{
    // 执行代码
}

四、调用函数


函数只有通过调用才可以执行函数内的代码。语法格式如下所示:

function_name()

五、使用案例


5.1 基础声明


// javascript
function sum(x,y) {
  return x + y;
}
// typescript
function sum(x: number, y: number): number {
  return x + y;
}
// 表达式
const sum = function (x: number, y: number): number {
  return x + y;
}

不过由于 TypeScript 可以根据 return 来推断返回的类型,因此有时候返回类型 number 并不是一定要书写的,不过为了给人阅读时不增加不必要的开支,写上明确的返回类型,是一种非常好的习惯。还有一点的是,虽然上述的代码我们已经为其添加了类型,不过这还不是一个很完整的类型书写,但往往我们可以忽略它,如:

type Sum = (x: number, y: number) => number;
const sum: Sum = function(x: number, y: number): number {
  return x + y;
}
复制代码

以往我们写 JavaScript 时调用 sum 函数,也许我们什么都不传,或者只传一个,但在 TypeScript 的世界中参数是必须真实存在的,我们调用时必须传递两个参数,因此我们可以使用 可选参数默认参数 的方式来处理这个问题,如:

function sum(x: number, y?: number): number {
}
function sum(x: number, y = 0): number {
}

5.2 TypeScript中arguments 处理


function sum(...num: number[]): number {
  return num[0] + num[1];
}

5.3 TypeScript中this的使用


let obj = {
  a: 1,
  b: function (){
    return () => {
      return this.a;
    }
  }
}

如果你没有使用箭头函数,那么这里的 this.a 会得到一个错误,因为此时的 this 会被设置为一个全局的对象,浏览器中是 window ,Node.js里是 global。


5.4 TypeScript重载功能


function sync(x: number): number;
function sync(x: { code: number, sig: string}): string;
function sync(x: any): any {
  if (typeof x === "number") {
    return 0;
  }
  if (typeof x === "string") {
    return "0";
  }
}
sync(0);

5.5 TypeScript中的e


const divDom = document.getElementById("div");
if (divDom) {
  const pay = function(current: number, discount: number): number{
    return current * (discount/100);
  }
  divDom.addEventListener("click", function(this: HTMLElement ,e: MouseEvent){
    pay(1000, 20);
  });
}

在这个例子中不仅用到了函数的类型,还有一个特别有意思的 this 的问题,请看下面代码:

divDom.addEventListener("click", function(this: HTMLElement ,e: MouseEvent){
  pay(1000, 20);
});
this: HTMLElement

其实是非常明确的指明 addEventListener 的 handler 函数的 this 的问题,这个 this 是指向了一个 HTML 元素对象,举个具体的例子,假设我们自己写了一个UI组件,提供了一个 addEventListener ,在处理 handler 函数时,应该将 this 指向这个这个UI组件实例,在 TypeScript 中写法如下:

class UI {
  public name: string;
  constructor(){
    this.name = "id";
  }
  public addEventListener(type: string, handler: (this: UI, e: string) => void) {
    ///
    handler.call(this, this.name);
  } 
}
const ui = new UI();
const onClick = ui.addEventListener("click", function(e: string){
  console.log(this.name);
})


目录
相关文章
|
13天前
|
存储 安全 JavaScript
TypeScript-内置应用程序类型-Recode
通过使用 `Record` 类型,开发者可以显著提升代码的安全性和可维护性。无论是配置对象、字典结构还是动态表单,`Record` 类型都提供了一个简洁、类型安全的解决方案。
187 82
|
3月前
|
设计模式 JavaScript 安全
TypeScript性能优化及代码质量提升的重要性、方法与策略,包括合理使用类型注解、减少类型断言、优化模块导入导出、遵循编码规范、加强代码注释等
本文深入探讨了TypeScript性能优化及代码质量提升的重要性、方法与策略,包括合理使用类型注解、减少类型断言、优化模块导入导出、遵循编码规范、加强代码注释等,旨在帮助开发者在保证代码质量的同时,实现高效的性能优化,提升用户体验和项目稳定性。
70 6
|
3月前
|
开发框架 JavaScript 前端开发
TypeScript 是一种静态类型的编程语言,它扩展了 JavaScript,为 Web 开发带来了强大的类型系统、组件化开发支持、与主流框架的无缝集成、大型项目管理能力和提升开发体验等多方面优势
TypeScript 是一种静态类型的编程语言,它扩展了 JavaScript,为 Web 开发带来了强大的类型系统、组件化开发支持、与主流框架的无缝集成、大型项目管理能力和提升开发体验等多方面优势。通过明确的类型定义,TypeScript 能够在编码阶段发现潜在错误,提高代码质量;支持组件的清晰定义与复用,增强代码的可维护性;与 React、Vue 等框架结合,提供更佳的开发体验;适用于大型项目,优化代码结构和性能。随着 Web 技术的发展,TypeScript 的应用前景广阔,将继续引领 Web 开发的新趋势。
64 2
|
3月前
|
JavaScript 安全 前端开发
TypeScript类型声明:基础与进阶
通过本文的介绍,我们详细探讨了TypeScript的基础与进阶类型声明。从基本数据类型到复杂的泛型和高级类型,TypeScript提供了丰富的工具来确保代码的类型安全和可维护性。掌握这些类型声明能够帮助开发者编写更加健壮和高效的代码,提高开发效率和代码质量。希望本文能为您在使用TypeScript时提供实用的参考和指导。
63 2
|
3月前
|
JavaScript 开发者
在 Babel 插件中使用 TypeScript 类型
【10月更文挑战第23天】可以在 Babel 插件中更有效地使用 TypeScript 类型,提高插件的开发效率和质量,减少潜在的类型错误。同时,也有助于提升代码的可理解性和可维护性,使插件的功能更易于扩展和升级。
|
4月前
|
JavaScript 前端开发
TypeScript【类型别名、泛型】超简洁教程!再也不用看臭又长的TypeScript文档了!
【10月更文挑战第11天】TypeScript【类型别名、泛型】超简洁教程!再也不用看臭又长的TypeScript文档了!
|
3月前
|
JavaScript 前端开发 安全
TypeScript进阶:类型系统与高级类型的应用
【10月更文挑战第25天】TypeScript作为JavaScript的超集,其类型系统是其核心特性之一。本文通过代码示例介绍了TypeScript的基本数据类型、联合类型、交叉类型、泛型和条件类型等高级类型的应用。这些特性不仅提高了代码的可读性和可维护性,还帮助开发者构建更健壮的应用程序。
48 0
|
5月前
|
JavaScript
typeScript进阶(9)_type类型别名
本文介绍了TypeScript中类型别名的概念和用法。类型别名使用`type`关键字定义,可以为现有类型起一个新的名字,使代码更加清晰易懂。文章通过具体示例展示了如何定义类型别名以及如何在函数中使用类型别名。
60 1
typeScript进阶(9)_type类型别名
|
4月前
|
JavaScript 前端开发 安全
深入理解TypeScript:增强JavaScript的类型安全性
【10月更文挑战第8天】深入理解TypeScript:增强JavaScript的类型安全性
82 0
|
4月前
|
JavaScript 前端开发 开发者
深入理解TypeScript:类型系统与实用技巧
【10月更文挑战第8天】深入理解TypeScript:类型系统与实用技巧