TypeScript 中的 object 和Object的区别

object 类型

  • object 类型是 TypeScript 中的一个非原始类型。
  • 它用于表示任何不是以下原始类型的数据类型:number、string、boolean、symbol、null 或 undefined
  • object 类型可以用来描述一个具有任意键值对的对象,也可以是数组、函数或者其他非原始类型的数据结构。
javascript 复制代码
let obj: object = { name: "Alice" }; // 普通对象
obj = [1, 2, 3]; // 数组也是 object 类型
obj = function() {}; // 函数也是 object 类型

Object 类型

  • Object 类型是 JavaScript 的构造函数,在 TypeScript 中它也被用作一个类型。
  • 当你使用 Object 作为类型时,它通常表示任何类型的值,因为 JavaScript 的所有值都最终继承自 Object
  • 在 TypeScript 中,Object 类型是一个通用类型,它相当于 any 类型,因为它允许分配任何类型的值。
javascript 复制代码
let obj: Object = { name: "Alice" };
obj = 42; // number 类型也是 Object 的实例
obj = "Hello"; // string 类型也是 Object 的实例
obj = true; // boolean 类型也是 Object 的实例

对于null的处理

javascript 复制代码
// typeof null === "object"
let value: unknown = null;
console.log(typeof value === "object");  // true

// 正确的检查方式
function isNonNullObject(value: unknown): value is object {
  return typeof value === "object" && value !== null;
}

数组类型

javascript 复制代码
// 数组是 object 类型
let arr: object = [1, 2, 3];  // OK
let arr2: Object = [1, 2, 3]; // OK

// 但无法访问数组方法
arr.length;   // Error
arr.push(4);  // Error

// 应该使用具体的数组类型
let arr3: number[] = [1, 2, 3];
arr3.length;  // OK
arr3.push(4); // OK
相关推荐
东东51629 分钟前
基于ssm的网上房屋中介管理系统vue
前端·javascript·vue.js
harrain2 小时前
什么!vue3.4开始,v-model不能用在prop上
前端·javascript·vue.js
阿蒙Amon7 小时前
TypeScript学习-第7章:泛型(Generic)
javascript·学习·typescript
睡美人的小仙女1277 小时前
Threejs加载环境贴图报错Bad File Format: bad initial token
开发语言·javascript·redis
fanruitian7 小时前
uniapp android开发 测试板本与发行版本
前端·javascript·uni-app
rayufo7 小时前
【工具】列出指定文件夹下所有的目录和文件
开发语言·前端·python
RANCE_atttackkk7 小时前
[Java]实现使用邮箱找回密码的功能
java·开发语言·前端·spring boot·intellij-idea·idea
摘星编程8 小时前
React Native + OpenHarmony:Timeline垂直时间轴
javascript·react native·react.js
2501_944525549 小时前
Flutter for OpenHarmony 个人理财管理App实战 - 支出分析页面
android·开发语言·前端·javascript·flutter
jin1233229 小时前
React Native鸿蒙跨平台完成剧本杀组队详情页面,可以复用桌游、团建、赛事等各类组队详情页开发
javascript·react native·react.js·ecmascript·harmonyos