新闻中心

J*aScript对象创建_工厂模式与建造者模式

2025-11-24
浏览次数:
返回列表
工厂模式用于批量创建结构相似的对象,通过函数封装创建逻辑,调用简便但无法识别类型;示例中createUser函数返回包含姓名、年龄、角色的对象并支持自我介绍。建造者模式适用于分步构建复杂对象,通过类方法链式调用逐步设置属性,最后由build方法生成对象,并可加入校验逻辑;如UserBuilder允许灵活配置用户信息。选择时,简单场景用工厂模式,复杂配置用建造者模式,两者均提升代码可维护性与灵活性。

javascript对象创建_工厂模式与建造者模式

在J*aScript中,创建对象的方式多种多样,工厂模式和建造者模式是两种常见且实用的设计模式。它们都能帮助我们更高效、灵活地生成对象,但适用场景和实现方式有所不同。下面分别介绍这两种模式的核心思想与代码实现。

工厂模式:批量创建相似对象

工厂模式适合用于创建多个结构相似的对象。它通过一个函数封装对象的创建过程,调用时传入参数,返回配置好的对象实例。这种方式避免了重复书写对象字面量或构造函数的繁琐。

工厂函数不依赖 thisnew,返回的是普通对象,使用起来简单直接。

示例:

```j*ascript function createUser(name, age, role) { return { name: name, age: age, role: role, introduce() { console.log(`我是${this.name},${this.age}岁,担任${this.role}`); } }; }

const user1 = createUser("小明", 25, "前端"); const user2 = createUser("小红", 28, "设计");

user1.introduce(); // 我是小明,25岁,担任前端 user2.introduce(); // 我是小红,28岁,担任设计

; alt="企业建站系统2.0">
                        </a>
                    </div>
                
<p>这种模式提升了可读性和灵活性,特别适用于可选参数多、配置项复杂的场景。</p>
<font>示例:</font>
<p>```j*ascript
class UserBuilder {
  constructor() {
    this.user = {};
  }

  setName(name) {
    this.user.name = name;
    return this; // 返回this以支持链式调用
  }

  setAge(age) {
    this.user.age = age;
    return this;
  }

  setRole(role) {
    this.user.role = role;
    return this;
  }

  build() {
    // 可加入校验逻辑
    if (!this.user.name) throw new Error("姓名不能为空");
    return { ...this.user };
  }
}

const user3 = new UserBuilder()
  .setName("小刚")
  .setAge(30)
  .setRole("后端")
  .build();

console.log(user3); // { name: "小刚", age: 30, role: "后端" }
```</p>
<p>建造者模式的优势在于流程清晰、易于扩展,还能在 build 阶段统一处理默认值或验证逻辑。</p>

<H3>如何选择?</H3>
<p>如果只是创建结构简单、差异小的对象,工厂模式足够用,代码简洁易懂。如果对象初始化过程复杂,需要逐步配置或有多个可选步骤,建造者模式更合适,能提升代码组织性。</p>
<p>两种模式都不依赖原型和继承,属于创建型设计模式中的灵活方案。理解它们的区别,有助于在实际开发中写出更清晰、可维护的对象创建逻辑。</p>
<p>基本上就这些。根据需求选择合适的模式,能让代码更健壮也更容易测试。

以上就是J*aScript对象创建_工厂模式与建造者模式的详细内容,更多请关注其它相关文章!


# java  # 前端  # javascript  # 洛阳营销推广多少钱  # 快速推广营销话术  # 登封网站SEO  # 网站建设建站教程怎么写  # 常州seo关键字  # seo赚300万  # 网站群建设技术方案  # 青海seo关键词排名优化软件  # 浙江网站建设网络推广  # 昌江区上门网站建设商家  # 适用于  # 两种  # 建站系统  # 自己的  # 官网  # 如何使用  # 链式  # 我是  # 多个  # 区别  # 后端 


相关栏目: 【 科技资讯46185 】 【 网络学院92790


相关推荐: 微信怎么把收藏的内容分类管理 微信收藏内容标签分类方法  C++如何操作注册表_Windows平台下C++读写注册表的API函数详解  如何在Promise链中优雅地中断后续then执行  微博网页版主页入口 微博官方网站免登录访问  AWS EC2实例间SQL Server连接超时:安全组配置与故障排除指南  优化LangChain文档加载与ChromaDB集成:解决多文档处理与分块问题  BetterDiscord插件中安全更新用户简介的实践指南  J*aScript中高效管理与清空动态列表:避免循环陷阱  Lar*el 递归关系中排除指定分支的教程  解决深度学习模型训练初期异常高损失与完美验证准确率问题  Django表单验证失败时保留用户输入数据的最佳实践  拼多多赚钱渠道_拼多多收益来源  Sublime Text怎么设置垂直标尺_Sublime配置Rulers规范代码长度  Kafka Streams中基于消息头条件过滤消息的实现指南  浏览器打开即用 美图秀秀网页版入口  凉拌黄瓜怎么拌更入味 凉拌黄瓜简单家常做法  Go语言中动态执行代码字符串的策略与实践  一加手机电池耗电快怎么办_一加手机电池耗电快的解决方法  Excel中VLOOKUP的第四个参数是干什么用的_Excel VLOOKUP第四参数作用解析  外媒分析《GTA6》定价:卖100美元可以但真没必要!  J*aScript动态修改指定div内所有a标签样式指南  J*a递归快速排序中静态变量导致数据累积问题的解决方案  MAC怎么安装Homebrew包管理器_MAC为开发者和高级用户安装命令行工具  微博网页版官方账号登录 微博网页版内容浏览使用指南  QQ邮箱官方网站登录入口_QQ邮箱网页版在线使用  谷歌浏览器怎么给标签页静音_Chrome标签静音快捷操作  在Runstone环境中高效处理TasteDive API的JSON数据  俄罗斯Yandex搜索引擎入口_Yandex官网免登录一键访问  狙击外星人小游戏开始_狙击外星人小游戏立即开始  印象笔记如何设提醒任务防漏执行_印象笔记设提醒任务防漏执行【任务提醒】  J*a应用集成GitHub CLI与API认证指南  iCloud登录入口网页版 苹果iCloud官网登录  126邮箱网页版官方入口 126邮箱账号在线登录平台  电脑屏幕颜色不舒服怎么办_Windows夜间模式与色彩校准教程【护眼技巧】  解决J*aScript中重复选择项的确认对话框显示问题  TikTok搜索结果不显示如何解决 TikTok搜索刷新优化方法  漫蛙MANWA漫画主页官方入口 漫蛙漫画最新在线阅读地址  composer的"require-dev"部分是用来做什么的?  AO3官方镜像站点汇总 AO3同人作品网页版直达链接  Django表单提交验证失败后保持字段值不刷新  如何在更新Composer依赖后自动运行测试_使用post-update-cmd钩子触发PHPUnit  J*a编写用户注册与登录功能_掌握字符串与验证逻辑  蛙漫官方正版入口 蛙漫网页在线全集免费观看  c++20的std::jthread是什么_c++可中断线程与RAII式管理  12306选座系统怎么选连座_12306选座多人连坐操作方法  Win11怎么开启省电模式_Win11电池节电模式自动开启  AO3最新可访问网址 Archive of Our Own官方在线入口  苹果手机指南针不准怎么校准 传感器校准方法详解【建议收藏】  汽水音乐车机版8.9下载 汽水音乐车机版8.9版本安装入口  UC浏览器如何安装插件 UC浏览器添加扩展程序详细教程【进阶】 

搜索