1、快速回顾一下这JavaScript中的命名函数和匿名函数:

纯文本查看 复制代码
1
2
3
4
5
//Named functionfunction add(x, y) {
    return x+y;
}
 
//Anonymous functionvar myAdd = function(x, y) { return x+y; };

2、TS简单函数例子

纯文本查看 复制代码
1
2
3
4
5
function add(x: number, y: number): number {
    return x+y;
}
 
var myAdd = function(x: number, y: number): number { return x+y; };

我们可以自定义每个参数和返回类型。
3、编写匿名函数一个函数的类型有相同的两个部分:参数和返回类型的类型。  这个名字只是帮助可读性。可以不一样,只要函数类型统一即可。

纯文本查看 复制代码
1
2
var myAdd: (baseValue:number, increment:number)=>number =
    function(x: number, y: number): number { return x+y; };

我们明确的返回类型使用(= >)表示。 
4、根据上下文判断返回类型
通过返回数据判断返回类型

纯文本查看 复制代码
1
2
3
4
// myAdd has the full function typevar myAdd = function(x: number, y: number): number { return x+y; };
 
// The parameters 'x' and 'y' have the type numbervar myAdd: (baseValue:number, increment:number)=>number =
    function(x, y) { return x+y; };

5、默认参数如下写法,必须传入指定的变量,否则报错。

 纯文本查看 复制代码
1
2
3
4
5
function buildName(firstName: string, lastName: string) {
    return firstName + " " + lastName;
}
 
var result1 = buildName("Bob")//error, too few parametersvar result2 = buildName("Bob", "Adams", "Sr.")//error, too many parametersvar result3 = buildName("Bob", "Adams")//ah, just right

我们在TS中使用?表示可选参数。 例如,我们希望最后一个参数是可选的:

纯文本查看 复制代码
1
2
3
4
5
6
7
8
function buildName(firstName: string, lastName?: string) {
    if (lastName)
        return firstName + " " + lastName;
    else
        return firstName;
}
 
var result1 = buildName("Bob")//works correctly nowvar result2 = buildName("Bob", "Adams", "Sr.")//error, too many parametersvar result3 = buildName("Bob", "Adams")//ah, just right

可选参数必须遵循必需的参数。 如果我们想让名可选而不是姓,我们需要改变参数在函数的顺序,把名字列表中的最后一个。

在TS中,我们还可以设定一个值,一个可选参数如果用户不提供。 这些被称为缺省参数。 让我们前面的示例和默认的姓“Smith”。

纯文本查看 复制代码
1
2
3
4
5
function buildName(firstName: string, lastName = "Smith") {
    return firstName + " " + lastName;
}
 
var result1 = buildName("Bob")//works correctly now, alsovar result2 = buildName("Bob", "Adams", "Sr.")//error, too many parametersvar result3 = buildName("Bob", "Adams")//ah, just right

如下为缺省参数,即包含默认值。

纯文本查看 复制代码
1
function buildName(firstName: string, lastName = "Smith") {

6、rest参数

纯文本查看 复制代码
1
2
3
4
5
function buildName(firstName: string, ...restOfName: string[]) {
        return firstName + " " + restOfName.join(" ");
}
 
var employeeName = buildName("Joseph", "Samuel", "Lucas", "MacKinzie");

使用...代表一个变量集合。 7、Lambdas和使用“this”this在js中的使用是相当混乱的。通常要根据上下文来判断其含义。

让我们来看一个例子:

纯文本查看 复制代码
01
02
03
04
05
06
07
08
09
10
11
12
13
14
15
16
17
var deck = {
    suits: ["hearts", "spades", "clubs", "diamonds"],
    cards: Array(52),
    createCardPicker: function() {
        return function() {
            var pickedCard = Math.floor(Math.random() * 52);
            var pickedSuit = Math.floor(pickedCard / 13);
 
            return {suit: this.suits[pickedSuit], card: pickedCard % 13};
        }
    }
}
 
var cardPicker = deck.createCardPicker();
var pickedCard = cardPicker();
 
alert("card: " + pickedCard.card + " of " + pickedCard.suit);

这时候会报错,因为this找不到suits,因为这个时候的this已经不是deck中的this了。

<1>为了解决这个问题,我们切换函数使用lambda表达式语法(()= > { })而不是JavaScript函数表达式。 这将自动捕获创建函数时可用的“this”:

纯文本查看 复制代码
01
02
03
04
05
06
07
08
09
10
11
12
13
14
15
16
17
18
var deck = {
    suits: ["hearts", "spades", "clubs", "diamonds"],
    cards: Array(52),
    createCardPicker: function() {
        // Notice: the line below is now a lambda, allowing us to capture 'this' earlier
        return () => {
            var pickedCard = Math.floor(Math.random() * 52);
            var pickedSuit = Math.floor(pickedCard / 13);
 
            return {suit: this.suits[pickedSuit], card: pickedCard % 13};
        }
    }
}
 
var cardPicker = deck.createCardPicker();
var pickedCard = cardPicker();
 
alert("card: " + pickedCard.card + " of " + pickedCard.suit);

<2>使用bind方法[希望我没有理解错]

纯文本查看 复制代码
01
02
03
04
05
06
07
08
09
10
11
12
13
14
15
16
var deck = {
    suits: ["hearts", "spades", "clubs", "diamonds"],
    cards: Array(52),
    createCardPicker: function() {
        return function() {
            var pickedCard = Math.floor(Math.random() * 52);
            var pickedSuit = Math.floor(pickedCard / 13);
 
            return {suit: this.suits[pickedSuit], card: pickedCard % 13};
        }
    }
}
 
var cardPicker = deck.createCardPicker().bind(deck);var pickedCard = cardPicker();
 
alert("card: " + pickedCard.card + " of " + pickedCard.suit);

更多信息方式,你可以阅读Yahuda卡茨 理解JavaScript函数调用和“this” 。 
==================================================

TypeScript教程3的更多相关文章

  1. TypeScript教程2

    在TS中,我们允许开发人员使用面向对象技术. 1.类让我们看看一个简单的基于类的例子: class Greeter { greeting: string; constructor(message: s ...

  2. TypeScript教程

    汇智课堂 地址  http://www.hubwiz.com/course/55b724ab3ad79a1b05dcc26c/ TypeScript是一种由微软开发的自由和开源的编程语言.它是Java ...

  3. TypeScript 教程&手册

    参考:https://www.w3cschool.cn/typescript/ https://www.gitbook.com/book/zhongsp/typescript-handbook/det ...

  4. TypeScript教程1

    Boolean类型aser:和as3一样 var isDone: boolean = false; 复制代码 Number类型aser:as3经常用int和uint,以后只用number就可以啦 va ...

  5. 2018-05-09 5分钟入门CTS-尝鲜中文版TypeScript

    知乎原链 本文为中文代码示例之5分钟入门TypeScript的CTS版本. CTS作者是@htwx(github). 它实现了关键词和标准库的所有命名汉化. 本文并未使用附带的vscode相关插件(包 ...

  6. HowToDoInJava 其它教程 1 &#183; 翻译完成

    原文:HowToDoInJava 协议:CC BY-NC-SA 4.0 欢迎任何人参与和完善:一个人可以走的很快,但是一群人却可以走的更远. ApacheCN 学习资源 目录 Maven 教程 如何在 ...

  7. 【electron+vue3+ts实战便笺exe】一、搭建框架配置

    不要让自己的上限成为你的底线 前言 诈尸更新系列,为了跟上脚步,尝试了vue3,在学习vue3的时候顺便学习一手electron和ts,本教程将分别发布,源码会在最后的文章发布.因为还在开发中,目前也 ...

  8. 100 个常见错误「GitHub 热点速览 v.22.35」

    本周的特推非常得延续上周的特点--会玩,向别人家的女朋友发送早安.这个错误是如何发生的呢?如何有效避免呢?自己用 daily_morning 免部署.定制一个早安小助手给女友吧. 除了生活中的错误,工 ...

  9. 转载:TypeScript 简介与《TypeScript 中文入门教程》

    简介 TypeScript是一种由微软开发的自由和开源的编程语言.它是JavaScript的一个超集,而且本质上向这个语言添加了可选的静态类型和基于类的面向对象编程.安德斯·海尔斯伯格,C#的首席架构 ...

随机推荐

  1. 根据XPATH去查看修改xml文件节点的内容

    首先给出xml文件解析的路径,然后去读取节点的内容. package com.inetpsa.eqc.threads; import java.util.List; import java.io.Fi ...

  2. openstack controller ha测试环境搭建记录(二)——配置corosync和pacemaker

    corosync.conf请备份再编辑:# vi /etc/corosync/corosync.conf totem {        version: 2 token: 10000        t ...

  3. Unity NGUI UIPanel下对粒子的剪裁

    使用 unity 做游戏开发时,有时需要在scroll view下使用粒子,但粒子是不会被 UIPanel 所裁剪的,本人提供了脚本 ParticleSystemClipper,用来处理这种情况.思路 ...

  4. iOS平台软件开发工具(一)-新建的工程使用CocoaPods工具集成第三方框架

    CocoaPods是一款集合了上千个第三方开源库的开发工具,能够大幅度的提升团队项目的开发效率,降低时间成本. 那么就看一下CocoaPods这个工具在项目中的使用体现吧. 我们马上用ASIHTTPR ...

  5. css01

      1.  常用属性:①color:文本颜色:②background-color:背景颜色:③font-size:文字大小: 2.  样式声明:①内部样式:style=“样式规则:”,写于作用标签内, ...

  6. Thinking in scala (8)---- 乘幂计算

    递归的方式: b^n = (b^(n/2))^2 若n是偶数 b^n = b*(b^(n-1)) 若n是奇数 迭代的方式 product:存储中间结果,初始化为1 b^n = (b^2)^(n/2) ...

  7. mysql 安装错误 解决方法

    错误及警告信息:TIMESTAMP with implicit DEFAULT value is deprecated. Please use --explicit_defaults_for_time ...

  8. VB.NET中网络编程所需组件WinHTTP的添加

    VB.NET中网络编程所需组件: WinHTTP组件:项目-->添加引用-->COM选项卡-->Microsoft WinHTTP Services,version 5.1--> ...

  9. 原生JavaScript之“淘宝轮播图”

    轮播图是我们学习原生js的必经之路 它包含很多基本知识的运用,像this的使用,DOM的操作,还有setInterval的使用和清除,浮动与定位等等,很好的考察了我们的基础知识牢不牢固, 话不多说,直 ...

  10. Android滚动选择控件

    现在觉得github特别方便,我一般直接使用github中的内容, https://github.com/wangjiegulu/WheelView 这里面都有详细的介绍