[angularjs之我见]注入器

深入探讨AngularJS注入器的使用方法,包括注入器的基本概念、主要功能、注入方式和时间发生机制,同时详细解释了DI过程及其在模块配置和运行块中的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

刚开始看angularjs时,总是云里雾里的,出现了很多新的理念。最后硬着头皮看源码,还真发现许多奇妙处,记录下来:

注入器Injector

 

anguarjs的注入器主要是用来将provider作为参数注入到被注入的函数中。

其包合:

1.invoke(fn, self, locals):通过fn的参数列表(获取[]方式指定,或$inject)得到需要注入的provider作为fn的参数调用fn。

注:如果提供了locals,系统会先通过locals查找注入列表,只有找不到时,才找provider

 

args.push(
        locals && locals.hasOwnProperty(key)
           ? locals[key]: getService(key)
);

 2.annotate(fn),获得注入列表

 

有三种方式:

A.通过推测来注释:通过函数参数推断

B.显式注释:在函数中指定$inject

C.内联注释:通过数组方式,最后一个元素为函数

 

3.instantiate(Type, locals):通过Type创建一个实力化对象,Type函数默认支持DI

其实他的原理是通过Type创建对象,再通过invoke函数实现DI,此时第二个参数self为创创建的对象。

 

4.get(serviceName):调用getService,根据serviceName获取provider,此时很重要的是provider的cache,和获取的方式。

有两种注入器,一种是ProviderInjector,另外是InstanceInjector

他们的cache分别是providerCache和instanceCache

而且获取方式分别为:

 

 

function () {
    throw $injectorMinErr('unpr', "Unknown provider: {0}", path.join(' <- '));
}

和

function (servicename) {
    var provider = providerInjector.get(servicename + providerSuffix);
    return instanceInjector.invoke(provider.$get, provider);
}

 从上可以看出,providerCache一定存在指定的provider,否则会报错。

InstanceInjector获取时,会先从providerCache中获得provider,再通过instanceInjector的invoke,对获得的provider的$get函数做DI,所以这就是为何provider必须体供$get的函数的原因。

 

 

那DI是什么时间发生的呢?

1.在module的config中

module中的config ==>providerCache中的$injector的invoke,

此时$injector为providerInjector,所以config函数注入的将是providerCache中的Provider.

 

2.在module的runBlocks中

 

此时调用的是instanceInjector的invoke,所以被注入的都是instanceCache的Provider

 

以下是module体供的方法:

provider ==>providerCache中的$provide的provider,

factory ==>providerCache中的$provide的factory,

service ==>providerCache中的$provide的service,

value ==>providerCache中的$provide的value,

constant ==>providerCache中的$provide的constant

 

 

 

 

1. 用户与身体信息管理模块 用户信息管理: 注册登录:支持手机号 / 邮箱注册,密码加密存储,提供第三方快捷登录(模拟) 个人资料:记录基本信息(姓名、年龄、性别、身高、体重、职业) 健康目标:用户设置目标(如 “减重 5kg”“增肌”“维持健康”)及期望周期 身体状态跟踪: 体重记录:定期录入体重数据,生成体重变化曲线(折线图) 身体指标:记录 BMI(自动计算)、体脂率(可选)、基础代谢率(根据身高体重估算) 健康状况:用户可填写特殊情况(如糖尿病、过敏食物、素食偏好),系统据此调整推荐 2. 膳食记录与食物数据库模块 食物数据库: 基础信息:包含常见食物(如米饭、鸡蛋、牛肉)的名称、类别(主食 / 肉类 / 蔬菜等)、每份重量 营养成分:记录每 100g 食物的热量(kcal)、蛋白质、脂肪、碳水化合物、维生素、矿物质含量 数据库维护:管理员可添加新食物、更新营养数据,支持按名称 / 类别检索 膳食记录功能: 快速记录:用户选择食物、输入食用量(克 / 份),系统自动计算摄入的营养成分 餐次分类:按早餐 / 午餐 / 晚餐 / 加餐分类记录,支持上传餐食照片(可选) 批量操作:提供常见套餐模板(如 “三明治 + 牛奶”),一键添加到记录 历史记录:按日期查看过往膳食记录,支持编辑 / 删除错误记录 3. 营养分析模块 每日营养摄入分析: 核心指标计算:统计当日摄入的总热量、蛋白质 / 脂肪 / 碳水化合物占比(按每日推荐量对比) 微量营养素分析:检查维生素(如维生素 C、钙、铁)的摄入是否达标 平衡评估:生成 “营养平衡度” 评分(0-100 分),指出摄入过剩或不足的营养素 趋势分析: 周 / 月营养趋势:用折线图展示近 7 天 / 30 天的热量、三大营养素摄入变化 对比分析:将实际摄入与推荐量对比(如 “蛋白质摄入仅达到推荐量的 70%”) 目标达成率:针对健
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值