新闻中心

J*aScript依赖注入容器

2025-10-17
浏览次数:
返回列表
依赖注入是通过外部注入依赖实现控制反转,提升解耦与可测试性;文中给出构造函数注入示例及简易DI容器实现,支持单例与瞬时生命周期管理,最后介绍使用场景与成熟库InversifyJS。

javascript依赖注入容器

J*aScript中的依赖注入(Dependency Injection, DI)容器是一种设计模式工具,用于管理对象之间的依赖关系,提升代码的可测试性、可维护性和解耦程度。在大型应用中,手动创建和管理依赖容易导致代码混乱,而DI容器能自动解析并注入所需依赖。

什么是依赖注入?

依赖注入的核心思想是:不主动在类内部创建依赖实例,而是由外部将依赖“注入”进来。这样可以实现控制反转(Inversion of Control, IoC),让模块之间更加松耦合。

常见的注入方式包括:

  • 构造函数注入:通过构造函数传入依赖
  • 属性注入:将依赖赋值给对象属性
  • 方法注入:通过方法参数传递依赖

为什么需要DI容器?

当项目变大,依赖层级加深时,手动管理依赖会变得繁琐且易错。DI容器的作用是:

迷你天猫商城 迷你天猫商城

迷你天猫商城是一个基于Spring Boot的综合性B2C电商平台,需求设计主要参考天猫商城的购物流程:用户从注册开始,到完成登录,浏览商品,加入购物车,进行下单,确认收货,评价等一系列操作。 作为迷你天猫商城的核心组成部分之一,天猫数据管理后台包含商品管理,订单管理,类别管理,用户管理和交易额统计等模块,实现了对整个商城的一站式管理和维护。所有页面均兼容IE10及以上现代浏览器。部署方式1、项目

迷你天猫商城 0 查看详情 迷你天猫商城
  • 自动解析依赖树,按需创建实例
  • 支持单例、瞬时等多种生命周期管理
  • 集中注册和配置服务,便于维护
  • 方便替换实现(如用mock替换真实服务进行测试)

一个简单的DI容器实现

下面是一个轻量级的DI容器示例,使用Map存储注册的服务,并支持构造函数注入:

class Container {
  constructor() {
    this.registry = new Map();
    this.instances = new Map(); // 缓存单例
  }

  register(name, ctor, lifecycle = 'singleton') {
    this.registry.set(name, { ctor, lifecycle });
    return this;
  }

  resolve(name) {
    if (!this.registry.has(name)) {
      throw new Error(`Service not registered: ${name}`);
    }

    const { ctor, lifecycle } = this.registry.get(name);

    if (lifecycle === 'singleton' && this.instances.has(name)) {
      return this.instances.get(name);
    }

    const instance = this._instantiate(ctor);
    
    if (lifecycle === 'singleton') {
      this.instances.set(name, instance);
    }

    return instance;
  }

  _instantiate(ctor) {
    const paramRegex = /constructor\s*\(\s*([^)]*)\)/;
    const argsStr = ctor.toString().match(paramRegex)?.[1] || '';
    const deps = argsStr.split(',').map(arg => arg.trim()).filter(Boolean);

    const dependencies = deps.map(dep => {
      if (!this.registry.has(dep)) {
        throw new Error(`Dependency not registered: ${dep}`);
      }
      return this.resolve(dep);
    });

    return Reflect.construct(ctor, dependencies);
  }
}

使用示例

假设我们有两个服务:Logger 和 UserService:

class Logger {
  log(msg) {
    console.log('[LOG]', msg);
  }
}

class UserService {
  constructor(Logger) {
    this.logger = Logger;
  }

  getUser(id) {
    this.logger.log(`Fetching user ${id}`);
    return { id, name: 'John Doe' };
  }
}

// 使用容器
const container = new Container();
container.register('Logger', Logger);
container.register('UserService', UserService);

const userService = container.resolve('UserService');
userService.getUser(1); // [LOG] Fetching user 1

基本上就这些。这个简易容器展示了DI的核心机制。实际项目中,也可以使用成熟的库,比如 InversifyJS,它支持装饰器、类型绑定和更复杂的场景,适合TypeScript项目。

以上就是J*aScript依赖注入容器的详细内容,更多请关注其它相关文章!


# java  # 关键词网站排名怎么看  # 重庆网站建设重点  # 营销推广ppt模板推荐夏天  # 上海贴心seo优化  # 保健品推广的营销方式  # 物流唐山网站优化方案  # seo关键词排名wl云速捷宀  # 相关文章  # 所需  # 是由  # 有哪些  # 是一种  # 如何实现  # 如何用  # 如何使用  # 是一个  # 可以使用  # red  # 为什么  # ai  # 工具  # typescript  # js  # javascript  # 独立网站怎么建设出来  # 江西seo营销怎么赚钱  # 忻州网站建设的优势 


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


相关推荐: 俄罗斯方块最新版入口 俄罗斯方块在线玩官网入口  CSS图片焦点样式实现教程:理解与应用tabindex属性  内存检查:在VS Code中调试C++时的内存视图  在Go Martini框架中高效服务动态生成图像的实践指南  深入理解Go语言中Map值与方法接收器的交互:为什么需要临时变量  台积电1.4nm工艺A14瞄准2028:10年来性能提升80%  必由学官方登录入口 必由学教师学生账号快速访问  Composer如何处理Git子模块(submodule)依赖_Composer与Git Submodule的对比与选择  Lar*el递归关系中排除子孙节点的策略  在Blazor WebAssembly应用中动态注入客户端特定指标代码的策略  微信聊天记录怎么加密_微信聊天记录加密方法  J*aScript DOM操作:高效清空列表元素的策略与实践  C++如何进行游戏物理模拟_使用Box2D库为C++游戏添加2D物理效果  必由学登录入口 必由学官方网站在线访问链接  抖音网页版企业服务中心登录入口_抖音网页版企业登录平台  修复二维数组索引越界异常:一维循环到二维坐标的正确映射  Go语言中高效处理x-www-form-urlencoded表单数据  打开就能玩的植物大战僵尸 植物大战僵尸网页版传送门  html怎么运行外部js文件中的函数_运html外js文件函数法【技巧】  yy漫画网页版官方入口_yy漫画官网登录页面链接  海量存储:机器视觉智能化的核心基石  C++的std::mdspan是什么_C++23中用于操作多维数组的非拥有视图  Lar*el Excel导入时生成自定义递增ID的策略与实践  钉钉视频会议声音异常如何处理 钉钉会议音频修复技巧  Golang如何使用context实现超时取消_Golang context超时取消模式实践  QQ邮箱正确登录入口_QQ邮箱官方网站使用地址  树莓派传感器触发:通过Twilio API发送WhatsApp消息教程  谷歌google账号怎么注册账号 谷歌账号注册官方流程  zookeeper 都有哪些功能?  J*a中实现Go语言select通道多路复用机制  J*a TimerTask文件监控:HashMap状态管理与常见陷阱规避指南  C++如何检测键盘输入_C++ _kbhit与_getch函数非阻塞输入  Composer的 archive 命令怎么用_快速打包你的PHP项目及其Composer依赖  Archive of Our Own官网直达 AO3最新可用地址一览  如何在更新Composer依赖后自动运行测试_使用post-update-cmd钩子触发PHPUnit  智慧团建扫码登录入口 智慧团建扫码登录入口官网版​  C++如何实现单例模式_C++设计模式之线程安全的单例写法  GemBox Document HTML转PDF垂直文本渲染问题及解决方案  响应式CSS Grid布局:优化网格项在小屏幕下的堆叠与宽度适配  支付宝如何设置安全保护_支付宝安全设置的全面教程  LINUX下如何进行磁盘分区_fdisk与parted工具在LINUX中的使用对比  Win11 USB传输速度慢怎么解决 Win11 USB驱动更新与设置  qq浏览器打开空白页怎么办 qq浏览器启动后显示白屏的解决教程  J*a递归快速排序中静态变量的状态管理与陷阱  飞书妙记怎样用语音转文字速记_飞书妙记用语音转文字速记【速记方法】  Windows10怎么开启夜间模式 Windows10系统设置调整色温与亮度缓解夜间用眼疲劳【教程】  哔哩哔哩忘记密码了怎么找回_哔哩哔哩密码找回方法  AO3官方在线访问地址 Archive of Our Own最新镜像合集  React/Next.js中实现列表项的动态选择与移动  html怎么在cmd下运行php文件_cmd运行html中php文件方法【教程】 

搜索