一段会报错的angular代码

@Injectable()
class Socket {
constructor(private buffer: Buffer) { }
} console.log(Buffer); // undefined @Injectable()
class Buffer {
constructor(@Inject(BUFFER_SIZE) private size: Number) { }
} console.log(Buffer); // [Function: Buffer]

翻译一下

    var providerList = new Map();
function Injectable(cls, deps) {
providerList.set(cls, {
deps: deps,
instance: null
});
} function inject(cls) {
var instanceObj = providerList.get(cls);
if (instanceObj === undefined) {
return null;
} else if (instanceObj.instance === null) {
var deps = instanceObj.deps.map(dep => inject(dep));
var instance = cls.apply({}, deps);
instanceObj.instance = instance;
return instance;
} else {
return instanceObj.instance;
}
} var Socket = (function() {
function Socket(buffer) {
this.buffer = buffer;
return this;
}
Injectable(Socket, [Buffer]);
return Socket;
}()); var Buffer = (function () {
function Buffer() {
this.sayHello = function() {
console.log('hello, i am Buffer.');
}
return this;
}
Injectable(Buffer, []);
return Buffer;
}()); var socket = inject(Socket);
socket.buffer.sayHello();
Socket被注入的时候,他的依赖Buffer还是undefined状态,最后取出来的就是undefined.
看看angular怎么用forwardRef解决这个问题的
@Injectable()
class Socket {
constructor(@Inject(forwardRef(() => Buffer) private buffer) { }
} @Injectable()
class Buffer {
constructor() { }
}

翻译一下

    function forwardRef(forwardRefFn) {
forwardRefFn.__forward_ref__ = forwardRef;
return forwardRefFn;
} function resolveForwardRef(type) {
if (typeof type === 'function' && type.hasOwnProperty('__forward_ref__') && type.__forward_ref__ === forwardRef) {
return type();
} else {
return type;
}
} var providerList = new Map(); function Injectable(cls, deps) {
providerList.set(cls, {
deps: deps,
instance: null
});
} function inject(cls) {
cls = resolveForwardRef(cls);
var instanceObj = providerList.get(cls);
if (instanceObj === undefined) {
return null;
} else if (instanceObj.instance === null) {
var deps = instanceObj.deps.map(dep => inject(dep));
var instance = cls.apply({}, deps);
instanceObj.instance = instance;
return instance;
} else {
return instanceObj.instance;
}
} var Socket = (function() {
function Socket(buffer) {
this.buffer = buffer;
return this;
}
Injectable(Socket, [forwardRef(() => Buffer)]);
return Socket;
}()); var Buffer = (function () {
function Buffer() {
this.sayHello = function() {
console.log('hello, i am Buffer.');
}
return this;
}
Injectable(Buffer, []);
return Buffer;
}()); var socket = inject(Socket);
socket.buffer.sayHello();

原理就是依赖不再是类了,而是一个返回类的函数,这样在inject的时候避免注入undefined。

												

angular里forwardRef的原理的更多相关文章

  1. angular的多个模块执行 angular里 字符串与对象的互转

    1.disable : true ,禁用 2.$timeout 计时器 $interval.cancel(timer); 3.app.run();  可以不使用控制器就开启数据,但适合$rootsco ...

  2. angular里使用vue/vue组件怎么在angular里用

    欢迎加入前端交流群交流知识&&获取视频资料:749539640 如何在angularjs(1)中使用vue参考: https://medium.com/@graphicbeacon/h ...

  3. 第217天:深入理解Angular双向数据绑定的原理

    一.理解angular双向数据绑定 双向绑定是新的前端框架中频繁出现的一个新词汇,也是mvvm的核心原理.angularjs五条核心信念中的数据驱动,便是由双向绑定进行完成. 那么什么是双向绑定,下面 ...

  4. $.ajax 的速度要快于 angular 里 $http (个别情况)

    $.ajax: $http:

  5. angular里forRoot的作用

    模块A是这样定义的 @NgModule({ providers: [AService], declarations: [ TitleComponent ], exports: [ TitleCompo ...

  6. Angular里使用(image-compressor.js)图片压缩

    参考资料: http://www.imooc.com/article/40038 https://github.com/xkeshi/image-compressor 示例代码: <nz-upl ...

  7. GCD: 求两数最大公因数算法【欧几里得法】原理的个人理解 (80%图片讲解!)

    那么,求 a,b 的最大公因数就是求最大的,能均分a,b的块!  

  8. angular原理及模块简介

    Angular简介(大神可略过) Angular是一个强大的前端框架,其强大之处主要是可以把静态页面与动态数据绑定起来.平时我们看到的网页界面上面的数据都是固定,但如果我们要变化这些数据,例如我在一个 ...

  9. 30行代码让你理解angular依赖注入:angular 依赖注入原理

    依赖注入(Dependency Injection,简称DI)是像C#,java等典型的面向对象语言框架设计原则控制反转的一种典型的一种实现方式,angular把它引入到js中,介绍angular依赖 ...

随机推荐

  1. jQuery.extend()[$.extend()]

    jQuery.extend(target, object1[,objectN]);jQuery.extend([deep], target, object1[,objectN]);jQuery.ext ...

  2. unity---克隆/贴图/平移/旋转

    克隆 GameObject clone =Instantiate(gameObject,new Vector3(10,10,10),Quaternion.identity); Destroy(clon ...

  3. 使用 Vite 插件开发构建 Tampermonkey 用户脚本

    起因 一直以来,我都是直接在浏览器 Tampermonkey 扩展页面直接新建用户脚本来开发的: 对于一些简单的脚本,这没有什么问题,即改即看.但当代码多了以后问题就来了,自带编辑器开发体验确实不太舒 ...

  4. AMS 新闻视频广告的云原生容器化之路

    作者 卓晓光,腾讯广告高级开发工程师,负责新闻视频广告整体后台架构设计,有十余年高性能高可用海量后台服务开发和实践经验.目前正带领团队完成云原生技术栈的全面转型. 吴文祺,腾讯广告开发工程师,负责新闻 ...

  5. 行列式&矩阵树定理

    行列式: 参考 oi-wiki 定义 对于一个\(n*n\)的矩阵A行列式取值(标量) \(det(A)=|A|=\sum\limits_p(-1)^{\tau(p)}\prod\limits_{i= ...

  6. 记一次 JDK SPI 配置不生效的问题 → 这么简单都不会,还是回家养猪吧

    开心一刻 今天去幼儿园接小侄女,路上聊起了天 小侄女:小叔,今天我吃东西被老师发现了 我:老师说了什么 小侄女:她说拿出来,跟小朋友一起分享 我:那你拿出来了吗 小侄女一脸可怜的看向我,说道:没有,我 ...

  7. Java - 四种引用类型及应用场景

    1. 强引用 new 一个对象的时候,就是强引用 Object object = new Object(); 只要强引用存在,垃圾回收就不会回收该对象,内存不足时会抛出OOM. 2. 软引用 定义:非 ...

  8. split(),strip,split("/")[-1] 和 split("/",-1)的区别

    Python中split()函数,通常用于将字符串切片并转换为列表. 一.函数说明: split():语法: str.split(str="",num=string.count(s ...

  9. C#中的CSV文件读写

    目录 CSV文件标准 文件示例 RFC 4180 简化标准 读写CSV文件 使用CsvHelper 使用自定义方法 基于简化标准的写CSV文件 使用TextFieldParser解析CSV文件 使用正 ...

  10. C# Winform程序界面优化实例

    进入移动互联网时代以来,Windows桌面开发已经很久不碰了.之前就是从做Windows开发入行的. 当年,还是C++ VC6, MFC的时代.那时候开发要查的是MSDN :-).内存要自己管理, 排 ...