成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

TypeScript 初識 - 函數(shù)

ARGUS / 1739人閱讀

摘要:函數(shù)類型函數(shù)返回值類型我們可以給每個參數(shù)添加類型之后再為函數(shù)本身添加返回值類型。能夠根據(jù)返回語句自動推斷出返回值類型,所以通??梢允÷运涿瘮?shù)完整函數(shù)類型完整的函數(shù)類型包含兩部分參數(shù)類型和返回值類型。

函數(shù)是 JavaScript 的第一等公民,函數(shù)在 JavaScript 中可以實現(xiàn)抽象層、模擬類、信息隱藏和模塊等等。TypeScript 在一定基礎(chǔ)上擴(kuò)展了函數(shù)的功能。

函數(shù)類型 函數(shù)返回值類型

我們可以給每個參數(shù)添加類型之后再為函數(shù)本身添加返回值類型。TypeScript 能夠根據(jù)返回語句自動推斷出返回值類型,所以通??梢允÷运?/p>

function add(x: number, y: number): number {
    return x + y;
}

// 匿名函數(shù)
let myAdd = function(x: number, y: number): number {
    return x + y;
};
完整函數(shù)類型

完整的函數(shù)類型包含兩部分:參數(shù)類型和返回值類型。

// (x: number, y: number) => number 為函數(shù)的類型
// 其中的 x、y 只是為了增加可讀性,只要參數(shù)類型是匹配的,無需匹配參數(shù)名是否一樣
// 參數(shù)類型和返回值類型之間使用 => 符號
let myAdd: (x: number, y: number) => number = function(
    x: number,
    y: number
): number {
    return x + y;
};

返回值類型是函數(shù)類型的必要部分,函數(shù)沒有返回值的情況,也必須要指定返回值為 void。

推斷類型

函數(shù)定義的時候,如果賦值語句只有一邊指定了語句,TypeScript 編譯器會自動識別出類型:

// myAdd has the full function type
let myAdd = function(x: number, y: number): number {
    return x + y;
};

// The parameters `x` and `y` have the type number
let myAdd: (baseValue: number, increment: number) => number = function(x, y) {
    return x + y;
};

這叫做“按上下文歸類”,是類型推論的一種。

可選參數(shù)和默認(rèn)參數(shù)

默認(rèn)情況下,TypeScript 會判斷傳入函數(shù)的參數(shù)和函數(shù)定義的參數(shù)是否一致,個數(shù)、類型都會進(jìn)行判斷。

let myAdd: (baseValue: number, increment: number) => number = function(x, y) {
    return x + y;
};

// An argument for "increment" was not provided.
myAdd(1);
myAdd(1, 2);
// 應(yīng)有 2 個參數(shù),但獲得 3 個。
myAdd(1, 2, 3);

在 TypeScript 中,可以加上 ? 實現(xiàn)可選參數(shù)的功能,可選參數(shù)必須放在必需參數(shù)的前面:

function buildName(firstName: string, lastName?: string) {
    if (lastName) {
        return firstName + " " + lastName;
    } else {
        return firstName;
    }
}

// Bob
let result1 = buildName("Bob");
// 應(yīng)有 1-2 個參數(shù),但獲得 3 個。
let result2 = buildName("Bob", "Adams", "Sr.");
// Bob Adams
let result3 = buildName("Bob", "Adams");

在定義函數(shù)的時候,可以給形參進(jìn)行賦值作為默認(rèn)值,僅當(dāng)不傳值或傳入的值為 undefined 時,函數(shù)會使用這個默認(rèn)值:

function buildName(firstName: string, lastName = "Smith") {
    return firstName + " " + lastName;
}

// Bob Smith
let result1 = buildName("Bob");
// Bob Smith
let result2 = buildName("Bob", undefined);

函數(shù)的默認(rèn)值不需要放到必需參數(shù)的后面,但是,放在必需參數(shù)前面的默認(rèn)值,只有顯式地傳遞 undefined 時會生效。

剩余參數(shù)

在 JavaScript 中,可以使用 arguments 訪問傳入的所有參數(shù);在 TypeScript 中同樣可以使用。

剩余參數(shù)將不定數(shù)量的參數(shù)當(dāng)作一個數(shù)組,表示 0 或多個參數(shù):

// ... 后面加上一個數(shù)組,這就是剩余參數(shù)
function buildName(firstName: string, ...restOfName: string[]) {
    return firstName + " " + restOfName.join(" ");
}

// Bob
console.log(buildName("Bob"));
// Bob Smith Steven
console.log(buildName("Bob", "Smith", "Steven"));

言下之意,剩余參數(shù)必須是最后的參數(shù),不能夠放到其他參數(shù)的前面。

重載

重載允許一個函數(shù)接受不同數(shù)量或類型的參數(shù)時,作出不同的處理。在 JavaScript 中,一般是判斷傳入?yún)?shù)的個數(shù)或類型等等情況實現(xiàn)重載。

以 TypeScript 中聯(lián)合類型的特性,實現(xiàn) JavaScript 版本的重載:

function reverse(x: number | string): number | string {
    if (typeof x === "number") {
        return Number(
            x
                .toString()
                .split("")
                .reverse()
                .join("")
        );
    }
    return x
        .split("")
        .reverse()
        .join("");
}

// function reverse(x: string | number): string | number
console.log(reverse(123));
console.log(reverse("123"));

上面是是實現(xiàn)重載的一個方法,但是這樣實現(xiàn)重載更難懂,不能精確表達(dá)。TypeScript 提供更能精確表達(dá)的重載方法:

function reverse(x: number): number;
function reverse(x: string): string;
function reverse(x: number | string): number | string {
    if (typeof x === "number") {
        return Number(
            x
                .toString()
                .split("")
                .reverse()
                .join("")
        );
    }
    return x
        .split("")
        .reverse()
        .join("");
}

// function reverse(x: number): number (+1 overload)
console.log(reverse(123));
// function reverse(x: string): string (+1 overload)
console.log(reverse("123"));

注意,TypeScript 會優(yōu)先從最前面的函數(shù)定義開始匹配,所以多個函數(shù)定義如果有包含關(guān)系,需要優(yōu)先把精確的定義寫在前面。

文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/106980.html

相關(guān)文章

  • TypeScript 初識 - 變量

    摘要:通常會定義為函數(shù)的返回值一個類型的變量是沒有生命用處的,因為類型的變量只能賦值為。和有一些區(qū)別的,函數(shù)沒有返回值時返回類型為的方法,即使沒有寫明語句,也會在函數(shù)執(zhí)行完的時候,隱式地返回一個類型。中新增加的變量聲明方式。 類型注解 類型注解使用 :TypeAnnotation 語法。類型聲明空間中可用的任何內(nèi)容都可以用作類型注解。 const num: number = 123; fun...

    dinfer 評論0 收藏0
  • TypeScript 初識 - 接口

    摘要:接口的作用是聲明變量的結(jié)構(gòu)和方法,但不做具體的實現(xiàn)。這兩個使用場景不同。額外的屬性檢查從字面上的意思看,其實就是對接口未定義的屬性進(jìn)行檢查。上面的例子,定義了接口,它具有索引簽名。它不會幫你檢查類是否具有某些私有成員。 接口的作用是聲明變量的結(jié)構(gòu)和方法,但不做具體的實現(xiàn)。通常,接口會強(qiáng)制對所有成員進(jìn)行類型檢查,包括數(shù)量和類型: interface Name { first: s...

    gnehc 評論0 收藏0
  • TypeScript 初識 - 類

    摘要:抽象類抽象類做為其它字類的基類使用,一般不會直接被實例化。抽象類中可以包含具體實現(xiàn),接口不能。抽象類在運(yùn)行時是可見的,可以通過判斷。接口只能描述類的公共部分,不會檢查私有成員,而抽象類沒有這樣的限制。 一個普通的類 class Greeter { greeting: string; constructor(message: string) { this....

    鄒強(qiáng) 評論0 收藏0
  • TypeScript 初識

    摘要:當(dāng)你陷在一個中大型項目中時應(yīng)用日趨成為常態(tài),沒有類型約束類型推斷,總有種牽一發(fā)而動全身的危機(jī)和束縛??傮w而言,這些付出相對于代碼的健壯性和可維護(hù)性,都是值得的。目前主流的都為的開發(fā)提供了良好的支持,比如和。參考資料中文文檔 文章博客地址:http://pinggod.com/2016/Typescript/ TypeScript 是 JavaScript 的超集,為 JavaScrip...

    iliyaku 評論0 收藏0
  • TypeScript 初識 - 枚舉

    摘要:當(dāng)滿足以下條件時,枚舉成員被當(dāng)作是常數(shù)不具有初始化函數(shù)并且之前的枚舉成員是常數(shù)。在這種情況下,當(dāng)前枚舉成員的值為上一個枚舉成員的值加。但第一個枚舉元素是個例外。枚舉成員使用常數(shù)枚舉表達(dá)式初始化。 數(shù)字類型枚舉 常規(guī)枚舉的值都是數(shù)字類型,因此被稱為數(shù)字類型枚舉: enum Color { Red, Blue, Green } console.log(Color.R...

    molyzzx 評論0 收藏0

發(fā)表評論

0條評論

ARGUS

|高級講師

TA的文章

閱讀更多
最新活動
閱讀需要支付1元查看
<