jira项目笔记15-TypeScript 的类型

简介: 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}
相关文章
|
20天前
|
JavaScript 前端开发 Java
TypeScript 类型兼容性
TypeScript 类型兼容性
|
20天前
|
JavaScript 前端开发
typescript 混合类型
typescript 混合类型
|
4天前
|
JavaScript 前端开发 IDE
TypeScript中的声明文件(.d.ts):扩展类型系统
TypeScript的`.d.ts`声明文件为JS库提供类型信息,增强IDE支持,如自动完成和类型检查。通过声明合并,可在全局作用域定义类型。示例包括为`my-library`创建声明模块,导出函数和接口。声明文件通常存于`@types`或指定`typeRoots`。用于旧JS代码的类型注解,如`myGlobalObject`。学习更多,参阅TypeScript官方文档。分享你的TS声明文件经验!
|
16天前
|
JavaScript 前端开发 安全
TypeScript:静态类型的动态语言
【6月更文挑战第9天】TypeScript是JavaScript的静态类型超集,解决JS类型安全问题,提供更强的代码组织和维护。它引入静态类型、接口和类,增强类型安全,减少运行时错误。TS与JS无缝集成,兼容现有库和框架,拥有丰富的开发工具和活跃社区。广泛应用在各种规模项目中,尤其提升复杂前端应用的代码质量。学习TypeScript对提升开发效率和代码可靠性极具价值。
25 10
|
12天前
|
监控 JavaScript 前端开发
如何在现有的 JavaScript 项目中渐进式地采用 TypeScript
【6月更文挑战第13天】TypeScript,JavaScript的超集,引入静态类型和更多特性,提升代码安全性和可读性。在JavaScript项目中渐进式采用TypeScript可从新模块开始,逐步转换代码,编写.d.ts文件支持第三方库,配置编译选项,并编写测试用例。通过监控和评估,改善项目质量和效率。大型项目尤其受益于TypeScript的类型安全、社区支持和工具兼容性。
26 3
|
14天前
|
前端开发 JavaScript 安全
TypeScript作为一种静态类型的JavaScript超集,其强大的类型系统和面向对象编程特性为微前端架构的实现提供了有力的支持
【6月更文挑战第11天】微前端架构借助TypeScript提升开发效率和代码可靠性。 TypeScript提供类型安全,防止微前端间通信出错;智能提示和自动补全加速跨代码库开发;重构支持简化代码更新。通过定义公共接口确保一致性,用TypeScript编写微前端以保证质量。集成到构建流程确保顺利构建打包。在微前端场景中,TypeScript是强有力的语言选择。
29 2
|
20天前
|
JavaScript
TypeScript 泛型类型
TypeScript 泛型类型
|
22天前
|
JavaScript
23.【TypeScript 教程】条件类型
23.【TypeScript 教程】条件类型
12 2
|
22天前
|
JavaScript 开发者
22.【TypeScript 教程】映射类型
22.【TypeScript 教程】映射类型
14 2
|
22天前
|
索引 JavaScript 前端开发
21.【TypeScript 教程】索引类型
21.【TypeScript 教程】索引类型
17 2