TypeScript學(xué)習(xí)-Functions

Optional and Default Parameters

  • 如果默認(rèn)參數(shù)被用作尾參數(shù)冀自,那么它起的作用和尾參數(shù)是可選的作用是一樣的:
function buildName(firstName: string, lastName?: string) {
    // ...
}
function buildName(firstName: string, lastName = "Smith") {
    // ...
}
(firstName: string, lastName?: string) => string
  • 可選參數(shù)如果有咧纠,那么只能放在尾參數(shù)
  • 默認(rèn)參數(shù)位置任意惠勒,其類型由默認(rèn)值決定双藕,也就是說(shuō)如果賦值了矫俺,那么值只能是設(shè)定的默認(rèn)值的類型或者undefined
function buildName(firstName = "sss", lastName: string) {
    return firstName + " " + lastName;
}
let result3 = buildName(undefined | string , "ssss");
console.log(result3);

Rest Parameters

  • ...用于無(wú)窮個(gè)可選參數(shù)币励,用于類型里面定義rest參數(shù)
function buildName(firstName: string, ...restOfName: string[]) {
    return firstName + " " + restOfName.join(" ");
}
let buildNameFun: (fname: string, ...rest: string[]) => string = buildName;

this

this是在函數(shù)調(diào)用時(shí)被設(shè)定的變量

let deck = {
    suits: ["hearts", "spades", "clubs", "diamonds"],
    cards: Array(52),
    createCardPicker: function() {
        return function() {
            let pickedCard = Math.floor(Math.random() * 52);
            let pickedSuit = Math.floor(pickedCard / 13);
            return {suit: this.suits[pickedSuit], card: pickedCard % 13};
        }
    }
}
let cardPicker = deck.createCardPicker();
let pickedCard = cardPicker();
//出錯(cuò)慷蠕,this.suits[pickedSuit] this被綁定到了 window | undefined
alert("card: " + pickedCard.card + " of " + pickedCard.suit);

thisarrow function

  • 通過(guò)使用arrow function綁定函數(shù)的上下文
  • 可以通過(guò)執(zhí)行加上--noImplicitThis來(lái)幫助提醒可能存在的綁定上下文錯(cuò)誤
let deck = {
    suits: ["hearts", "spades", "clubs", "diamonds"],
    cards: Array(52),
    createCardPicker: function() {
        // NOTE: the line below is now an arrow function, allowing us to capture 'this' right here
        return () => {
            let pickedCard = Math.floor(Math.random() * 52);
            let pickedSuit = Math.floor(pickedCard / 13);

            return {suit: this.suits[pickedSuit], card: pickedCard % 13};
        }
    }
}
let cardPicker = deck.createCardPicker();
let pickedCard = cardPicker();
alert("card: " + pickedCard.card + " of " + pickedCard.suit);

this parameter

  • 然而,即使arrow function綁定了上下文,但是食呻,this.suits[pickedSuit]的類型依然是any,因?yàn)?code>this來(lái)源于對(duì)象字面量?jī)?nèi)部的函數(shù)表達(dá)式
  • 所以TypeScript提供一個(gè)this parameter來(lái)修復(fù)這個(gè)bug
interface Card {
    suit: string;
    card: number;
}
interface Deck {
    suits: string[];
    cards: number[];
    createCardPicker(this: Deck): () => Card;
}
let deck: Deck = {
    suits: ["hearts", "spades", "clubs", "diamonds"],
    cards: Array(52),
    // NOTE: The function now explicitly specifies that its callee must be of type Deck
    createCardPicker: function(this: Deck) {
        return () => {
            let pickedCard = Math.floor(Math.random() * 52);
            let pickedSuit = Math.floor(pickedCard / 13);

            return {suit: this.suits[pickedSuit], card: pickedCard % 13};
        }
    }
}
let cardPicker = deck.createCardPicker();
let pickedCard = cardPicker();
alert("card: " + pickedCard.card + " of " + pickedCard.suit);

這樣就修復(fù)了bug流炕,TypeScript知道了this的類型是Deck,就沒(méi)有any錯(cuò)誤了

  • this parameter in callbacks
    當(dāng)函數(shù)作為參數(shù)傳入一個(gè)一個(gè)庫(kù)中的函數(shù)中的時(shí)候仅胞,這些庫(kù)會(huì)把傳入的函數(shù)當(dāng)做普通的函數(shù)處理每辟,因此這個(gè)函數(shù)捕獲的this會(huì)變成undefined,所以在這個(gè)函數(shù)內(nèi)涉及到this的會(huì)報(bào)錯(cuò)干旧。
    通過(guò)以下幾步解決錯(cuò)誤渠欺,而且可以使用this
  • 首先通過(guò)fake parameter this,確保傳入的參數(shù)函數(shù)是不會(huì)捕獲this椎眯,第一層檢查挠将。
interface UIElement {
    addClickListener(onclick: (this: void, e: Event) => void): void;
}
  • 然后通過(guò)箭頭函數(shù)來(lái)幫忙
class Handler {
    info: string;
    onClickGood = (e: Event) => { this.info = e.message }
}

以上可以會(huì)有缺點(diǎn)胳岂。那就是每次傳建一個(gè)Handler類型的對(duì)象都會(huì)創(chuàng)建一個(gè)新的arrow function,造成浪費(fèi)捐名,解決辦法是在Handler的原型上創(chuàng)建公用的方法


Overloads

JavaScript函數(shù)對(duì)于不同的參數(shù)可能返回不同類型的對(duì)象等等旦万,所以需要如下措施來(lái)幫助做type-check

  • 通過(guò)overloads和調(diào)用函數(shù)相同名字的函數(shù)組,來(lái)檢查每一個(gè)可能產(chǎn)生的結(jié)果镶蹋。
let suits = ["hearts", "spades", "clubs", "diamonds"];
function pickCard(x: {suit: string; card: number; }[]): number;
function pickCard(x: number): {suit: string; card: number; };
function pickCard(x): any {
    // Check to see if we're working with an object/array
    // if so, they gave us the deck and we'll pick the card
    if (typeof x == "object") {
        let pickedCard = Math.floor(Math.random() * x.length);
        return pickedCard;
    }
    // Otherwise just let them pick the card
    else if (typeof x == "number") {
        let pickedSuit = Math.floor(x / 13);
        return { suit: suits[pickedSuit], card: x % 13 };
    }
}
let myDeck = [{ suit: "diamonds", card: 2 }, { suit: "spades", card: 10 }, { suit: "hearts", card: 4 }];
let pickedCard1 = myDeck[pickCard(myDeck)];
alert("card: " + pickedCard1.card + " of " + pickedCard1.suit);
let pickedCard2 = pickCard(15);
alert("card: " + pickedCard2.card + " of " + pickedCard2.suit);
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市赏半,隨后出現(xiàn)的幾起案子贺归,更是在濱河造成了極大的恐慌,老刑警劉巖断箫,帶你破解...
    沈念sama閱讀 216,372評(píng)論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件拂酣,死亡現(xiàn)場(chǎng)離奇詭異,居然都是意外死亡仲义,警方通過(guò)查閱死者的電腦和手機(jī)婶熬,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門(mén),熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)埃撵,“玉大人赵颅,你說(shuō)我怎么就攤上這事≡萘酰” “怎么了饺谬?”我有些...
    開(kāi)封第一講書(shū)人閱讀 162,415評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)谣拣。 經(jīng)常有香客問(wèn)我募寨,道長(zhǎng),這世上最難降的妖魔是什么森缠? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,157評(píng)論 1 292
  • 正文 為了忘掉前任拔鹰,我火速辦了婚禮,結(jié)果婚禮上贵涵,老公的妹妹穿的比我還像新娘列肢。我一直安慰自己,他們只是感情好独悴,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,171評(píng)論 6 388
  • 文/花漫 我一把揭開(kāi)白布例书。 她就那樣靜靜地躺著,像睡著了一般刻炒。 火紅的嫁衣襯著肌膚如雪决采。 梳的紋絲不亂的頭發(fā)上,一...
    開(kāi)封第一講書(shū)人閱讀 51,125評(píng)論 1 297
  • 那天坟奥,我揣著相機(jī)與錄音树瞭,去河邊找鬼拇厢。 笑死,一個(gè)胖子當(dāng)著我的面吹牛晒喷,可吹牛的內(nèi)容都是我干的孝偎。 我是一名探鬼主播,決...
    沈念sama閱讀 40,028評(píng)論 3 417
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼凉敲,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼衣盾!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起爷抓,我...
    開(kāi)封第一講書(shū)人閱讀 38,887評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤势决,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后蓝撇,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體果复,經(jīng)...
    沈念sama閱讀 45,310評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,533評(píng)論 2 332
  • 正文 我和宋清朗相戀三年渤昌,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了虽抄。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 39,690評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡独柑,死狀恐怖迈窟,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情群嗤,我是刑警寧澤菠隆,帶...
    沈念sama閱讀 35,411評(píng)論 5 343
  • 正文 年R本政府宣布,位于F島的核電站狂秘,受9級(jí)特大地震影響骇径,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜者春,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,004評(píng)論 3 325
  • 文/蒙蒙 一破衔、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧钱烟,春花似錦晰筛、人聲如沸。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,659評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)。三九已至拥刻,卻和暖如春怜瞒,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背般哼。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,812評(píng)論 1 268
  • 我被黑心中介騙來(lái)泰國(guó)打工吴汪, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留惠窄,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,693評(píng)論 2 368
  • 正文 我出身青樓漾橙,卻偏偏與公主長(zhǎng)得像杆融,于是被迫代替她去往敵國(guó)和親。 傳聞我的和親對(duì)象是個(gè)殘疾皇子霜运,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,577評(píng)論 2 353

推薦閱讀更多精彩內(nèi)容