新闻中心

js不同类型的工厂函数

2025-11-12
浏览次数:
返回列表
基础、私有状态、可配置、组合式工厂函数是J*aScript中常见的四种模式,分别适用于创建固定结构对象、隐藏数据、动态定制行为及多功能组合场景。

js不同类型的工厂函数

在 J*aScript 中,工厂函数是一种不依赖 new 操作符就能创建对象的函数。它们通过返回一个新对象来实现封装和复用。根据用途和结构的不同,可以将工厂函数分为几种常见类型。以下是几种典型的工厂函数模式及其使用场景。

基础对象工厂函数

最基本的工厂函数用于创建具有固定结构的对象,避免重复书写对象字面量。

例如,创建用户对象:

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

const user1 = createUser("Alice", 30);
user1.greet(); // 输出: Hello, I'm Alice
  

这种模式适合需要频繁生成相似对象的场景,代码清晰且易于维护。

带私有状态的工厂函数

利用闭包,工厂函数可以创建拥有私有属性和方法的对象,外部无法直接访问内部变量。

例如,实现一个计数器:

function createCounter() {
  let count = 0; // 私有变量

  return {
    increment() {
      count++;
    },
    decrement() {
      count--;
    },
    value() {
      return count;
    }
  };
}

const counter = createCounter();
counter.increment();
console.log(counter.value()); // 1
  

这种方式实现了数据隐藏,比构造函数 + prototype 更灵活地控制访问权限。

可配置行为的工厂函数

工厂函数可以接收配置参数,动态决定对象的行为或结构,适合构建可定制的实例。

ShopII电子商务社区 ShopII电子商务社区

v1.13更新:1.增加产品讨论功能(ProductMsg备注字段)2.修正页面中的js错误数处。3.删除后的拍卖产品在回收站中统一管理。4.版面图标的DIY..自己更换,表格颜色自由调配。5.无限分类结构优化。6.产品说明支持HTML.7.网页界面优化.8.修正产品上下跳转的条数错误。9.完善邮件群发功能,可选择发送给不同类型的商城用户。10.修正拍卖信息中错误的交易完成Bug。11.去掉搜索用

ShopII电子商务社区 0 查看详情 ShopII电子商务社区 比如创建不同类型的日志记录器:

function createLogger(type) {
  return {
    log(message) {
      if (type === 'console') {
        console.log(`[LOG] ${message}`);
      } else if (type === 'alert') {
        alert(`[LOG] ${message}`);
      }
    }
  };
}

const consoleLogger = createLogger('console');
const alertLogger = createLogger('alert');

consoleLogger.log("Hi"); // 打印到控制台
  

这种模式提升了灵活性,适用于插件系统或配置驱动的应用模块。

组合式工厂函数(Mixin 风格)

通过组合多个功能模块,工厂函数可以生成具备多种能力的对象,实现类似多重继承的效果。

例如:

function withData(state) {
  return {
    getData() { return state.data; },
    setData(val) { state.data = val; }
  };
}

function withMethods() {
  return {
    s*e() { console.log('S*ed!'); },
    reset() { this.setData(null); }
  };
}

function createEntity(initialData) {
  const state = { data: initialData };

  // 组合多个行为
  return {
    ...withData(state),
    ...withMethods()
  };
}

const entity = createEntity("initial");
entity.s*e(); // S*ed!
console.log(entity.getData()); // initial
  

这种风格支持高度解耦的设计,便于测试和功能复用。

基本上就这些常见的工厂函数类型。它们都不依赖 new,语法简洁,天然支持私有状态和组合扩展,在现代 JS 开发中广泛应用,特别是在不需要类继承的场景下是很好的选择。

以上就是js不同类型的工厂函数的详细内容,更多请关注其它相关文章!


# 复用  # 亳州网站关键词推广哪家正规  # 成都中小企业网站推广  # 吉林网站建设推广报价  # 潍坊seo结构优化  # 如何优化网站热门易速达  # 收录网站建设北路  # seo专业培训seo8  # 卫龙网络营销推广部门  # 用seo去运营抖音  # 宁波如何做seo  # 拖拽  # javascript  # 拖放  # 它与  # 如何使用  # 几种  # 适用于  # 多个  # 如何实现  # 不同类型  # js  # java 


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


相关推荐: composer 和 npm/yarn 在管理依赖方面有什么核心思想差异?  海棠账号登录入口_登录海棠账户同步阅读记录  Pandas DataFrame 多条件优先级排序与排名  高德地图怎么看全景照片_高德地图全景照片浏览教程  微信网页版扫码登录入口 微信网页版二维码登录入口  整合Supabase认证与Django模型:跨模式迁移的解决方案  虫虫漫画精品漫画官网_虫虫漫画精品漫画官网进入精品漫画  Python vgamepad库按键模拟:正确使用XUSB_BUTTON常量  sublime怎么预览Markdown渲染效果_Markdown Preview插件 for sublime教程  c++中的const_cast和reinterpret_cast怎么用_c++四种类型转换  C++ explicit关键字防止隐式转换_C++构造函数安全规范  钉钉视频会议声音异常如何处理 钉钉会议音频修复技巧  J*a递归快速排序中静态变量导致数据累积的陷阱与解决方案  c++20的std::jthread是什么_c++可中断线程与RAII式管理  漫蛙Manwa2官网入口地址分享 漫蛙漫画PC版永久访问通道  QQ邮箱网页版入口登录 QQ邮箱在线邮箱官方通道  如何为你的Composer包编写自动化测试_集成PHPUnit到Composer的scripts工作流  AO3最新官网入口公告_2025AO3镜像站实时查询方法  利用Bokeh CustomJS动态控制DataTable列可见性  c++ dfs和bfs代码 c++深度广度优先搜索算法  Angular中单选按钮的正确使用与常见陷阱解析  抖音小游戏合成大西瓜免费秒玩入口链接 抖音小游戏热门合集秒玩网站  win11如何加载ICC颜色配置文件 Win11校色文件安装与显示器色彩管理【指南】  Safari怎么安装扩展程序 浏览器插件安装与管理方法【详解】  一加Ace 6T支持全新明眸护眼:通过了最严苛的护眼小金标认证  印象笔记如何设提醒任务防漏执行_印象笔记设提醒任务防漏执行【任务提醒】  俄罗斯浏览器官网直达链接 俄罗斯浏览器最新在线入口导航  知音漫客正版漫画平台_知音漫客官网账号登录  AI泡沫首次被“刺破”:GPU十年都无法存活!  想当下一个《2077》?《心之眼》Steam评价升至"多半好评"  Go语言中Map存储的结构体如何调用指针方法:深入解析与实践  谷歌浏览器一键优化方案_谷歌浏览器直达主页极速不卡版  React中useState与局部变量:理解组件状态管理与渲染机制  AO3镜像入口大全 AO3网页版内容访问全集  邮政编码查询不到怎么办_邮政编码查询不到的常见原因与对策  TikTok搜索不到用户发布内容怎么办 TikTok用户内容搜索优化方法  Golang如何优化内存分配与垃圾回收_Golang内存管理与GC优化实践  Descript怎样用AI剪辑自动去噪_Descript用AI剪辑自动去噪【自动降噪】  Lar*el Form Request中唯一性验证在更新操作中的正确实现  理解Python模块与全局变量的作用域管理  利用5118提升短视频内容效果_5118短视频关键词优化方法  星露谷物语官网入口 星露谷物语游戏官网入口  微信网页版官方快速登录入口 微信网页版网页版账号直达  怎样使用“本地安全策略”提升Windows安全性_Secpol.msc配置指南【高手】  理解J*aScript Promise的微任务队列与执行顺序  夸克AO3官网入口_AO3镜像网站2025推荐  Lar*el递归关系中排除子孙节点的策略  微信网页版官方入口直达 微信网页版网页版登录使用方法  Yandex浏览器官方网页版入口 Yandex浏览器最新版官网  MAC怎么安装Homebrew包管理器_MAC为开发者和高级用户安装命令行工具 

搜索