首页 > web前端 > js教程 > 正文

如何在javascript中创建对象_工厂模式与构造函数有何不同?

紅蓮之龍
发布: 2025-12-23 20:54:08
原创
902人浏览过
工厂模式是普通函数,直接调用返回新对象,不依赖new且this无关紧要;构造函数需用new调用,通过this绑定属性方法,支持instanceof和原型继承。

如何在javascript中创建对象_工厂模式与构造函数有何不同?

工厂模式和构造函数都是创建对象的方式,但核心区别在于:工厂模式是普通函数,返回新对象;构造函数需用 new 调用,内部通过 this 绑定属性和方法,并隐式返回实例。

工厂模式:封装创建逻辑,不依赖 new

工厂函数本质是普通函数,接收参数,内部创建并返回一个新对象。它不修改 this,也不要求调用者使用 new,适合需要灵活返回不同类型对象的场景。

例如:

function createPerson(name, age) {
  return {
    name: name,
    age: age,
    greet() {
      return `Hello, I'm ${this.name}`;
    }
  };
}

const p1 = createPerson('Alice', 30); // ✅ 正常调用
const p2 = new createPerson('Bob', 25); // ❌ 无意义,不会报错但 this 指向错误
登录后复制
  • 每次调用都生成全新对象,方法无法复用(每个实例都有独立的 greet 函数)
  • 无法用 instanceof 判断类型(返回的是普通对象,没有构造器记录)
  • 适合简单、一次性、多变结构的对象创建,比如配置项、API 响应数据转换

构造函数:定义实例模板,配合 new 使用

构造函数约定首字母大写,内部用 this 添加属性和方法,必须通过 new 调用,才能正确绑定实例上下文并返回新对象。

超能文献
超能文献

超能文献是一款革命性的AI驱动医学文献搜索引擎。

超能文献 123
查看详情 超能文献

立即学习Java免费学习笔记(深入)”;

例如:

function Person(name, age) {
  this.name = name;
  this.age = age;
  this.greet = function() {
    return `Hello, I'm ${this.name}`;
  };
}

const p1 = new Person('Alice', 30); // ✅ 正确
const p2 = Person('Bob', 25);       // ❌ 错误:this 指向全局(非严格模式)或 undefined(严格模式)
登录后复制
  • 支持 instanceofp1 instanceof Person === true
  • 可通过原型(Person.prototype)共享方法,节省内存
  • 若忘记 new,容易引发静默错误(如污染全局对象),可用 new.target 防御

关键差异总结

  • 调用方式:工厂函数直接调用;构造函数必须加 new
  • this 行为:工厂函数中 this 无关紧要;构造函数中 this 指向新实例
  • 类型识别:工厂返回对象无构造器痕迹;构造函数实例保留 constructorinstanceof 能力
  • 扩展性:构造函数天然支持原型继承;工厂模式需手动处理共享行为(如闭包缓存、外部对象挂载)

现代替代建议

ES6 后,更推荐用 class(语法糖,底层仍是构造函数)或简洁的字面量/ Object.assign / Object.create 实现类似工厂逻辑。若需类型语义和继承能力,优先选 class;若只需轻量、无类型约束的对象组装,工厂函数依然清晰实用。

以上就是如何在javascript中创建对象_工厂模式与构造函数有何不同?的详细内容,更多请关注php中文网其它相关文章!

java速学教程(入门到精通)
java速学教程(入门到精通)

java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号