Skip to content
    在 Opshell 的 Blog 中:
  • 目前已分享 70 篇文章
  • 還有 114 個坑正在填補中
  • 已有: Loading 次觀看
  • 已有: Loading 個人來過
✍️ Opshell
📆 Last Updated:8/23/2024Created:2022/09/05
👀 已被閱讀: Loading

[Day05]-萬丈高樓平地起-基礎的型別

Day 05

所以說那個Type呢?

既然要學習TypeScript那Type就是它的醬汁───────────────────────── By Opshell


昨日重點複習:三種主要設定Type的方式

Title型別推論型別註記型別斷言
英文InferenceAnnotationAssertion
模式被動主動主動
內容自動推論資料型別大多使用在初始化階段,例如宣告變數、函式參數等手動指定、選擇一個值的型別
後續內容會說Inference(推論)Annotation(註記)Assertion(斷言)

今日目標:學會基本型的Type宣告,避開一些坑。


過程:

  • 1. 基本型介紹

    我們先來複習複習JS的型別:

    • number 數值
    • string 字串
    • boolean 布林值
    • null 查找不到物件
    • undefined 未定義
    • symbol(於 ES6 新定義)
  • 2. 基本型別的Type法

    typescript
     // TypeScript code
     let TS; // any
     let title = 'Opshell'; // string
     let age = 30; // number
     let hasPet = false; // boolean
     let car = undefined; // any
     let house = null; // any

    在 TypeScript 的 Inference(推論) 中: ※ 1. nullundefined 被稱為 Nullable Types   在未指名的情況下,Nullable Types會被Inference(推論)any

    ※ 2. 在TS 中,any 是非常難掌控的類型,畢竟他突破了TS 被創造出來的目的,   簡直就是混世大魔王,能不用,就不用,   如果用多了,還不如乾脆回頭寫JS就好。

    ※ 3. 也會注意到如果你一開始不和TS說內容是什麼,   也不Annotation(註記)他的類型,TS 就會當他是any,   原理是:在JS宣告時沒帶值就等於帶入undefined

    為了盡量不使用any,上面的宣告會使用Annotation(註記)變成這樣:

    typescript
     // TypeScript code
     let TS: undefined; // undefined
     let car: undefined = undefined; // undefined
     let house: null = null; // null

    但是這樣產生了另一個問題, 因為你已經Annotation(註記)了型別, 在你未來要用他的時候:

    typescript
     // TypeScript code
     let car: undefined = undefined; // undefined
    
     car = 'skoda fabia 2022';

    提醒

    你就會發現出現了一個TS的警告, 會告訴你型別是不一樣的, 這時候該怎麼辦呢? 這時候就會有個新技巧Union (聯集)

    typescript
     // TypeScript code
     let car: undefined | string = undefined; // 讓car可以是undefined 或 string
    
     car = 'skoda fabia 2022'; // 這時候就不會報錯了

小結:

今天學會了宣告基本型, 學會了盡量避開any坑, 稍微了解到了 每種Type法的配合, 跟什麼都沒學到一樣 。 我們明天見。


章節小結:

第一章結的內容就到這邊 相信大家對TypeScript是什麼、有什麼用、為什麼要用、該怎麼用 都有了基礎的認知, 也有可能會覺得好像真的不是很難, 但事情不是我們想的這麼簡單,一坑還有一坑坑, 在後續的幾天,會用例子和大家一起學習, 希望會對它的有更多的認知, 我們明天見~!

Released under the MIT License.