Typescript 的类型

TypeScript vs JavaScript

TypeScript 是 “强类型” 版的 JavaScript,当我们在代码中定义变量 (包括普通变量、函数、组件、hook 等) 的时候,TypeScript 允许我们在定义的同时指定其类型,这样使用者在使用不当的时候就会被及时报错提醒:

interface SearchPanelProps {
  users: User[],
  param: {
    name: string;
    personId: string;
  },
  setParam: (param: SearchPanelProps['param']) => void;
}

export const SearchPanel = ({users, param, setParam}: SearchPanelProps) => {}

经常用 TypeScript 的感受:比起原来的 JavaScript,TypeScript 带来了完全不一样的开发体验,bug 大大减少了,编辑器提示快了,代码更易读了, 开发速度快了(看似多写代码,其实由于前面几点节省了大量开发时间),上手了就回不去了。

TypeScript 的类型

8 种类型: number, string, boolean, function, array, any, void, object

1. number

数字类型,包含小数、其他进制的数字:

let decimal: number = 6;
let hex: number = 0xf00d;
let binary: number = 0b1010;
let octal: number = 0o744;
let big: bigint = 100n;

2. string

字符串

let color: string = "blue";

3. array

在 TS 中,array 一般指所有元素类型相同的值的集合,比如:

let list: Array<number> = [1, 2, 3];

// or

interface User {
  name: string
}
const john = {name: 'john'}
const jack = {name: 'jack'}
let personList = [john, jack] // 这里 john 和 jack 都是 User 类型的

而这种混合类型的 “数组”:

let l = ['jack', 10]

在 TS 中不是 数组 /array,它们叫作 tuple

4. boolean

布尔值:

let isDone: boolean = false;

5. 函数

两种方法:

1.在我们熟悉的 “JS 函数” 上直接声明参数和返回值:

const isFalsy = (value: any): boolean => { 
  return value === 0 ? true : !!value; 
}; 

2.直接声明你想要的函数类型:

export const useMount = (fn: () => void) => {
  useEffect(() => {
    fn();
  }, []);
};

const isFalsy: (value: any) => boolean = (value) => {
  return value === 0 ? true : !!value;
};

6. any

any 表示这个值可以是任何值,被定义为 any 就意味着不做任何类型检查:

let looselyTyped: any = 4;
// looselyTyped 的值明明是个4,哪里来的ifItExists方法呢?
// 由于声明为any,我们没法在静态检查阶段发现这个错误
looselyTyped.ifItExists();

应该尽量避免使用 any

7. void

绝大部分情况下,只会用在这一个地方:表示函数不返回任何值或者返回 undefined (因为函数不返回任何值的时候 === 返回 undefined)

export const useMount = (fn: () => void) => {
  useEffect(() => {
    fn();
  }, []);
};

8. object

除了 number, string, boolean, bigint, symbol, null, or undefined,其他都是 object。

9. tuple

这就是一个典型的 tuple:

const [users, setUsers] = useState([])

10. enum

enum Color {
  Red,
  Green,
  Blue,
}
let c: Color = Color.Green;

11. null 和 undefined

null 和 undefined 在 TypeScript 中既是一个值,也是一个类型:

let u: undefined = undefined;
let n: null = null;

12. unknown

unknown 表示这个值可以是任何值。
这句话怎么这么熟悉,刚才是不是用来形容 any 的?
unknown 的用法:在你想用 any 的时候,用 unknown 来代替,简单来说,unknown 是一个 "严格" 版的 any。

13. never

这个 func返回的就是never类型,用到比较少,在类型操作等场景会用到

const func = () => {
  throw new Error()
}

.d.ts

JS 文件 + .d.ts 文件 === ts 文件。
.d.ts 文件可以让 JS 文件继续维持自己 JS 文件的身份,而拥有 TS 的类型保护。
一般我们写业务代码不会用到,但是点击类型跳转一般会跳转到 .d.ts 文件。

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 213,558评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,002评论 3 387
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 159,036评论 0 349
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,024评论 1 285
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,144评论 6 385
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,255评论 1 292
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,295评论 3 412
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,068评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,478评论 1 305
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,789评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,965评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,649评论 4 336
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,267评论 3 318
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,982评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,223评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,800评论 2 365
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,847评论 2 351

推荐阅读更多精彩内容