▓▓▓▓▓▓ 大致介绍

  TypeScript为JavaScript函数添加了额外的功能,让我们可以更容易地使用。TypeScript中的函数也包括JavaScript中最常见的两种函数

  1. function add(x,y){
  2. return x + y;
  3. }
  4.  
  5. let add = function(x,y){
  6. return x + y;
  7. }

▓▓▓▓▓▓ 函数类型

  可以像变量一样为函数定义类型

  1. function add(x: number, y: number): number {
  2. return x + y;
  3. }
  4.  
  5. let myAdd = function(x: number, y: number): number { return x+y; };

  函数的完整类型

  1. let add: (x: number,y: number) => number =
  2. function(x: number,y: number): number { return x + y};

  完整的函数类型太过麻烦,推荐还是写简单的,而且如果函数没有返回值,最好设置为void,不要留空

▓▓▓▓▓▓ 可选参数和默认参数

  注意:在TypeScript中传递给一个函数的参数个数必须与函数期望的参数个数一致。

  1. function buildName(firstName: string, lastName: string) {
  2. return firstName + " " + lastName;
  3. }
  4.  
  5. let result1 = buildName("Bob"); // error
  6. let result2 = buildName("Bob", "Adams", "Sr."); // error
  7. let result3 = buildName("Bob", "Adams");

  可选参数应该可以猜到,没错,就是使用?

  1. function buildName(firstName: string, lastName?: string) {
  2. if (lastName)
  3. return firstName + " " + lastName;
  4. else
  5. return firstName;
  6. }
  7.  
  8. let result1 = buildName("Bob"); // works correctly now
  9. let result2 = buildName("Bob", "Adams", "Sr."); // error, too many parameters
  10. let result3 = buildName("Bob", "Adams"); // ah, just right

  默认参数都是老套路

  1. function buildName(firstName: string, lastName = "Smith") {
  2. return firstName + " " + lastName;
  3. }
  4.  
  5. let result1 = buildName("Bob");
  6. let result2 = buildName("Bob", undefined);
  7. let result3 = buildName("Bob", "Adams", "Sr."); // error, too many parameters
  8. let result4 = buildName("Bob", "Adams");

▓▓▓▓▓▓ 剩余参数

  有时,你想同时操作多个参数,或者你并不知道会有多少参数传递进来。 在JavaScript里,你可以使用arguments来访问所有传入的参数。

  在TypeScript里,你可以把所有参数收集到一个变量里:

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

  

  你也可以操作这个变量

  1. function buildName(firstName: string, ...restOfName: string[]) {
  2. return firstName + " " + restOfName.join(" ");
  3. }
  4.  
  5. let buildNameFun: (fname: string, ...rest: string[]) => string = buildName;

▓▓▓▓▓▓ this

  this是JavaScript中的难点之一,看看下面的代码

  1. let deck = {
  2. suits: ["hearts", "spades", "clubs", "diamonds"],
  3. cards: Array(52),
  4. createCardPicker: function() {
  5. return function() {
  6. let pickedCard = Math.floor(Math.random() * 52);
  7. let pickedSuit = Math.floor(pickedCard / 13);
  8.  
  9. return {suit: this.suits[pickedSuit], card: pickedCard % 13};
  10. }
  11. }
  12. }
  13.  
  14. let cardPicker = deck.createCardPicker();
  15. let pickedCard = cardPicker();
  16.  
  17. alert("card: " + pickedCard.card + " of " + pickedCard.suit);

  你的答案是什么?

  答案是报错!这时因为deck.createCardPicker()返回一个函数赋值给cardPicker,而cardPicker是以函数式的方式调用的,所以this指向window。之所以这样是因为在JavaScript中this是在被调用时确定的,而在TypeScript中可以将this设置为在函数定义时就确定,方法就是把函数表达式变为使用lambda表达式( () => {} )

  1. let deck = {
  2. suits: ["hearts", "spades", "clubs", "diamonds"],
  3. cards: Array(52),
  4. createCardPicker: function() {
  5. // NOTE: the line below is now an arrow function, allowing us to capture 'this' right here
  6. return () => {
  7. let pickedCard = Math.floor(Math.random() * 52);
  8. let pickedSuit = Math.floor(pickedCard / 13);
  9.  
  10. return {suit: this.suits[pickedSuit], card: pickedCard % 13};
  11. }
  12. }
  13. }
  14.  
  15. let cardPicker = deck.createCardPicker();
  16. let pickedCard = cardPicker();
  17.  
  18. alert("card: " + pickedCard.card + " of " + pickedCard.suit);

  这样就没有问题了

参考资料:

   TypeScript Handbook(中文版)

TypeScript入门-函数的更多相关文章

  1. TypeScript入门指南(JavaScript的超集)

    TypeScript入门指南(JavaScript的超集)   你是否听过 TypeScript? TypeScript 是 JavaScript 的超集,TypeScript结合了类型检查和静态分析 ...

  2. typescript 入门教程一

    ##### 从今天开始,持续更新typescript入门教程系列.... 目前ts越来越火,主流的前端框架,好比*angular,vue 3*均是采用ts来编写,所有很多公司的项目都是用**ts**来 ...

  3. TypeScript入门五:TypeScript的接口

    TypeScript接口的基本使用 TypeScript函数类型接口 TypeScript可索引类型接口 TypeScript类类型接口 TypeScript接口与继承 一.TypeScript接口的 ...

  4. TypeScript入门二:基本数据类型

    浅析基本数据类型 TypeScript类型解析 一.浅析基本数据类型 首先有一个问题TypeScript是一门编译型语言?还是解释性语言?显然已经不能被这两个分类来区分,TypeScript的并不是为 ...

  5. TypeScript 入门教程学习笔记

    TypeScript 入门教程学习笔记 1. 数据类型定义 类型 实例 说明 Number let num: number = 1; 基本类型 String let myName: string = ...

  6. TypeScript 入门自学笔记 — 类型断言(二)

    码文不易,转载请带上本文链接,感谢~ https://www.cnblogs.com/echoyya/p/14558034.html 目录 码文不易,转载请带上本文链接,感谢~ https://www ...

  7. Python入门-函数的使用到程序的公布安装

    Python入门-函数的使用到Python的公布安装 本文主要适合有一定编程经验,至少掌握一门编程语言的人查看. 文中样例大多都是简单到认识英文单词就能看懂的水平,主要讲的是Python的总体使用方法 ...

  8. ggplot2作图详解:入门函数qplot

    ggplot2作图详解:入门函数qplot   ggplot2的功能不用我们做广告,因为它的作者Hadley Wickham就说ggplot2是一个强大的作图工具,它可以让你不受现有图形类型的限制,创 ...

  9. TypeScript入门实例

    前言 TypeScript是JavaScript的超集,微软公司开发,利用es6语法,实现对js的面向对象编程思想,写代码的时候会像强类型语言一样,指定参数类型.返回值类型,类型不对会报错,但编译后还 ...

随机推荐

  1. 超出区域文字显示为省略号或者剪切效果——CSS的生僻操作

    每门语言总有那么一些不太常用,却又不可或缺的语法操作.下面说一下,在HTML文件中,如何设置用 "省略号" 和 "剪切" 代替大量文字的效果. 以下是HTML的 ...

  2. windows service宿主web api使用"依赖注入"和“控制反转”的技术实践

    前言 自从几年前抛弃wcf,使用web api 来做服务器端开发之后,就不再迷惑了.但是因为本来从事传统行业管理软件开发,一般都以分布式应用开发为主.纯BS还是比较少,于是比较喜欢用windows s ...

  3. jquery小测

    1.在div元素中,包含了一个<span>元素,通过has选择器获取<div>元素中的<span>元素的语法是? 提示使用has() $("div:has ...

  4. 用stm32f0x建立新的工程重要步骤

    stm32f10x系列新建空的工程主要原理: 1.添加启动文件 不同的芯片类型的启动文件的容量是不同的,选择适合该芯片的容量作为启动文件. 注意:启动文件是汇编语言编写的,所以文件的后缀名为.s 2. ...

  5. category类别中添加属性

    p.p1 { margin: 0.0px 0.0px 0.0px 0.0px; font: 18.0px Menlo; color: #c91b13 } p.p2 { margin: 0.0px 0. ...

  6. NSPredicate 查询/搜索

    IOS NSPredicate 查询.搜索   简述:Cocoa框架中的NSPredicate用于查询,原理和用法都类似于SQL中的where,作用相当于数据库的过滤取. 最常用到的函数 + (NSP ...

  7. ViewPager详解

    一.ViewPager简介 ViewPager 如其名所述,是负责翻页的一个 View.准确说是一个 ViewGrop,包含多个 View 页,在手指横向滑动屏幕时,其负责对 View 进行切换.为了 ...

  8. 学习一点Markdown的基本知识

    本文于2017年3月18日首发于LinkedIn,请参考链接 这个世界的进步是由一些"懒"的人推动的.今天讲的这个Markdown,其实也是因为一批厌倦了HTML的各种标签的语法, ...

  9. CSS规范 - 命名规则

    使用类选择器,放弃ID选择器 ID在一个页面中的唯一性导致了如果以ID为选择器来写CSS,就无法重用. NEC特殊字符:"-"连字符 "-"在本规范中并不表示连 ...

  10. web注册功能实现

    开发工具:Eclipse Web前端语言:html+jsp 后端数据库:MySQL 数据库UI工具:Navicat for MySQL (根据网上各位前辈的信息,自学实现这个注册基本功能,以后要是学到 ...