新闻中心
js不同类型的工厂函数
基础、私有状态、可配置、组合式工厂函数是J*aScript中常见的四种模式,分别适用于创建固定结构对象、隐藏数据、动态定制行为及多功能组合场景。

在 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电子商务社区
v1.13更新:1.增加产品讨论功能(ProductMsg备注字段)2.修正页面中的js错误数处。3.删除后的拍卖产品在回收站中统一管理。4.版面图标的DIY..自己更换,表格颜色自由调配。5.无限分类结构优化。6.产品说明支持HTML.7.网页界面优化.8.修正产品上下跳转的条数错误。9.完善邮件群发功能,可选择发送给不同类型的商城用户。10.修正拍卖信息中错误的交易完成Bug。11.去掉搜索用
0
查看详情
比如创建不同类型的日志记录器:
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为开发者和高级用户安装命令行工具


2025-11-12
浏览次数:次
返回列表
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