jira项目笔记15-TypeScript 的类型
TypeScript 的类型
8 种类型: number, string, boolean, 函数,array, any, void, object
这一节我们接触到了平常使用中会接触到的大部分的类型,下面我们挨个梳理一遍:
- number:数字类型,包含小数、其他进制的数字
let decimal: number = 6; let hex: number = 0xf00d; let binary: number = 0b1010; let octal: number = 0o744; let big: bigint = 100n;
- string:字符串
let color: string = "blue";
- 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,下面会提到。
- boolean:布尔值
let isDone: boolean = false;
- 函数
在我们熟悉的 “JS 函数” 上直接声明参数和返回值:
/** * 这是我们上节课写的代码,大家可能发现了 * 我在这里做了一些修改,在箭头前边加上了 :boolean * 但是在我们上节课的代码中是没有这个:boolean 的, * 之所以不需要加是因为 类型推断,这个我们在下面会讲 * @param value */ const isFalsy = (value: any): boolean => { return value === 0 ? true : !!value; };
直接声明你想要的函数类型:
/** * 上节课写的 useMount 和 isFalsy */ export const useMount = (fn: () => void) => { useEffect(() => { fn(); }, []); }; const isFalsy: (value: any) => boolean = (value) => { return value === 0 ? true : !!value; };
- any
any 表示这个值可以是任何值,被定义为 any 就意味着不做任何类型检查:
let looselyTyped: any = 4; // looselyTyped 的值明明是个4,哪里来的ifItExists方法呢? // 由于声明为any,我们没法在静态检查阶段发现这个错误 looselyTyped.ifItExists();
初学 TS 的同学经常会为了让 TS 不再报错就用了很多 any,这样做会失去 TS 的保护。同学们应该尽量避免使用 any
- void
绝大部分情况下,只会用在这一个地方:表示函数不返回任何值或者返回 undefined (因为函数不返回任何值的时候 === 返回 undefined)
/** * 上节课写的 useMount */ export const useMount = (fn: () => void) => { useEffect(() => { fn(); }, []); };
- object
除了 number, string, boolean, bigint, symbol, null, or undefined,其他都是 object。
下面是我们还没有接触到的 TS 类型。
- tuple
其实这个大家已经见过了,这是没有给大家指出来。
这就是一个典型的 tuple:
const [users, setUsers] = useState([])
tuple 是 “数量固定,类型可以各异” 版的数组。
在 React 中有可能使用 tuple 的地方就是 custom hook 的返回值,注意 isHappy → tomIsHappy 以及其他名字的变化,这里使用 tuple 的好处就显现出来了:便于使用者重命名:
const useHappy = () => { //.... return [isHappy, makeHappy, makeUnHappy] } const SomeComponent = () => { const [tomIsHappy, makeTomHappy, makeTomUnHappy] = useHappy(false) // ... }
- enum
enum Color { Red, Green, Blue, } let c: Color = Color.Green;
- null 和 undefined
null 和 undefined 在 TypeScript 中既是一个值,也是一个类型:
let u: undefined = undefined; let n: null = null;
- unknown
unknown 表示这个值可以是任何值。
这句话怎么这么熟悉,刚才是不是用来形容 any 的?
unknown 的用法:在你想用 any 的时候,用 unknown 来代替,简单来说,unknown 是一个 "严格" 版的 any。
const isFalsy = (value: unknown) => { // 大家不用考虑这段console有啥意义,把它打在你的代码里对应的位置,观察编辑器会不会报错; // 再思考它应不应该报错 console.log(value.mayNotExist) return value === 0 ? true : !!value; };
- never
// 这个 func返回的就是never类型,用到比较少,在类型操作等场景会用到 const func = () => { throw new Error() }
- interface
interface 不是一种类型,应该被翻译成 接口,或者说使用上面介绍的类型,创建一个我们自己的类型:
interface User { id: number; } const u: User = {id: 1}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 阿里最新开源QwQ-32B,效果媲美deepseek-r1满血版,部署成本又又又降低了!
· SQL Server 2025 AI相关能力初探
· AI编程工具终极对决:字节Trae VS Cursor,谁才是开发者新宠?
· 开源Multi-agent AI智能体框架aevatar.ai,欢迎大家贡献代码
· Manus重磅发布:全球首款通用AI代理技术深度解析与实战指南