JavaScript中对象创建应按需选择:字面量适合单例和静态数据,构造函数/class适用于多实例、方法复用与封装,工厂函数则提供无new的可控创建方式。

JavaScript 中创建对象,构造函数和字面量不是“非此即彼”的选择,而是服务于不同场景的工具。字面量更轻量、直观,适合一次性、结构简单、无需复用行为的对象;构造函数(或 class)更适合需要多个实例、共享方法、封装状态或涉及继承的场景。
对象字面量:简洁直接,适合静态数据和单例
当你只需要一个独立对象,比如配置项、API 响应数据、UI 状态快照,字面量是最自然的选择:
const user = { name: "张三", age: 28, isActive: true };
它声明即创建,无额外开销,可读性强,且天然支持属性简写、计算属性名、展开运算符等现代特性。所有属性默认可枚举、可修改(除非后续冻结),适合快速建模。
立即学习“Java免费学习笔记(深入)”;
构造函数 / class:面向实例,支持方法复用与封装
当你需要创建多个相似对象,并希望它们共享方法、隔离私有状态或统一初始化逻辑时,构造函数或 class 更合适:
class Car {
constructor(brand, model) {
this.brand = brand;
this.model = model;
}
start() { return `${this.brand} ${this.model} 发动了`; }
}
const car1 = new Car("Toyota", "Camry");
const car2 = new Car("Honda", "Civic");
此时 方法定义在原型上,所有实例共享一份函数代码,节省内存;构造过程可校验参数、设置默认值、触发副作用(如日志、事件);配合 # 私有字段或闭包还能实现真正的封装。
实际开发中怎么选?看三个关键点
- 是否需要多个实例? —— 是 → 构造函数/class;否 → 字面量优先
- 是否需复用行为(方法)? —— 是 → 方法放原型更合理;仅存数据 → 字面量足够
- 是否涉及初始化逻辑或约束? —— 如验证必填字段、转换格式、关联其他对象 → 构造函数提供明确入口
补充说明:工厂函数是折中方案
如果想避开 new 关键字又需要封装逻辑,工厂函数很实用:
function createUser(name, email) {
if (!name || !email.includes("@")) throw new Error("参数无效");
return { name, email, createdAt: new Date() };
}
const u = createUser("李四", "lisi@example.com");
它结合了字面量的灵活性和构造函数的可控性,没有原型链,适合生成不可变或轻量对象,也便于单元测试。











