亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

typescript nodejs 依賴注入實現方法代碼詳解

2019-11-19 11:09:32
字體:
來源:轉載
供稿:網友

依賴注入通常也是我們所說的ioc模式,今天分享的是用typescript語言實現的ioc模式,這邊用到的主要組件是 reflect-metadata 這個組件可以獲取或者設置元數據信息,它的作用是拿到原數據后進行對象創建類似C#中的反射,先看第一段代碼:

import "reflect-metadata";/** * 對象管理器 */const _partialContainer = new Map<string, any>();const PARAMTYPES = "design:paramtypes";//需要反射的原數據,有很多種選擇,我們這里選擇的是拿到構造函數的參數類型,為了后續判斷/** * 局部注入器,注入的是全局服務,實例是全局共享 */export function Inject(): ClassDecorator {  return target => {    const params: Array<any> = Reflect.getMetadata(PARAMTYPES, target);    if (params)      for (const item of params) {        if (item === target) throw new Error("不能注入自己");      }    _partialContainer.set(target.name, target);//加入到對象管理器中,這個時候對象還沒有被創建  }}

   上面的代碼是創建一個類級別的裝飾器,表示凡是使用了這個裝飾器的類都會被依賴注入對象管理器管理,這里沒有馬上創建服務,原因是reflect-metadata的執行有先機是最高的,而這個依賴注入是支持手動注入一些實例對象,所有為了防止出現注入參數為undefined所以創建實例的工作是放在后面的,請看接下來的代碼:

/** * * @param type 已創建的實例對象 */export function addServiceInGlobal(...types: Array<Object>) {  for (const iterator of types) {    _partialContainer.set(iterator.constructor.name, iterator);  }}

 上面的方法是手動注入實例對象時調用的,我們需要提高這個方法的執行優先級,具體的實例會在后面演示,接下來是最重要部分,創建實例部分:

export function serviceProvider<T>(service: ServiceType<T>): T {  if (_partialContainer.has(service.name) && !_partialContainer.get(service.name).name)    return _partialContainer.get(service.name);// 如果實例已經被創建就直接返回   const params: Array<any> = Reflect.getMetadata(PARAMTYPES, service);// 反射拿到構造函數的參數類型  const constrparams = params.map(item => { // 實例化參數中的依賴    if (!_partialContainer.has(item.name)) throw new Error(`${item}沒有被注入`);// 如果沒有注入就拋出異常    if (item.length)// 表示這個類型還有其它依賴      return serviceProvider(item);// 遞歸繼續獲取其他依賴    if (_partialContainer.has(item.name) && !_partialContainer.get(item.name).name)      return _partialContainer.get(item.name);// 如果實例已經被創建就直接返回    const obj = new item();// 已經沒有其他依賴了 開始創建實例    _partialContainer.set(item.name, obj);// 替換對象管理器中原來沒有實例化的對象    return obj;  });  const obj = new service(...constrparams); // 這里表示對象沒有被創建,開始創建對象  _partialContainer.set(service.name, obj);// 替換對象管理器中原來沒有實例化的對象  return obj;}

 上面代碼寫的稍微有一點點復雜,其他理解起來也不困難,大白話講就是 如果已經實例化了直接返回實例不然就開始對象以及創建出所有的依賴。接下來是例子:

import { serviceProvider, addServiceInGlobal, Inject } from './core/injectable/injector';import "reflect-metadata";import moment = require('moment');@Inject()export class ServiceA{  property?:string;  msg(){    return "ServiceA";  }}@Inject()export class ServiceC {  constructor(private service: ServiceA) { }  print() {   console.log( this.service.property);    return "調用了我";  }}@Inject()export class ServiceD{  print(){   console.log("我在測試注入");  }}@Inject()export class GlobalService {  constructor(private service: ServiceC) { }  msg!: string;  print() {    console.log(`共享模塊${this.service.print()}`)  }}@Inject()export class Init {  constructor(private service: ServiceA,    private serviceD: ServiceD,    private global: GlobalService,    private date: Date,    private strList: string[],    private serviceC: ServiceC,  ) { }  start() {    console.log(this.service.msg());    this.service.property = "A模塊設置的共享數據"    console.log(moment(this.date).format("YYYY-MM-DD"))    console.log(this.strList);    this.serviceD.print();    this.serviceC.print();    this.global.print();  }} const obj = new Date("2017-1-1");const str = ['呂順彬','菜鳥','豆豆','大鐵','CC哥','碼農之家的一群人'];addServiceInGlobal(obj, str); // 添加手動創建的實例對象到對象管理器const service = serviceProvider(Init); // 開始創建實例service.start()// 執行

上面的實例中得到一下執行結果:

總結:上面我用的是默認全局注入,沒有做singletion (單例) ,如果要做的話稍微修改下代碼就可以實現,這里邊的難點可能是基于反射的設計方法,如果前端思維可能理解起來稍微困難點,后臺的話稍微好點。

總結

以上所述是小編給大家介紹的typescript nodejs 依賴注入實現方法代碼詳解,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的!

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲一级片在线看| 国产精品亚洲视频在线观看| 国产精品久久久久7777婷婷| 中文字幕一区二区三区电影| 日韩精品极品视频| 91日本在线视频| 亚洲国产天堂久久综合网| 伊人久久男人天堂| 最近2019年好看中文字幕视频| 55夜色66夜色国产精品视频| 欧美与欧洲交xxxx免费观看| 国产精品日韩在线一区| 欧美日韩亚洲视频| 国产精品88a∨| 欧美一区三区三区高中清蜜桃| 亚洲国产中文字幕在线观看| 欧美最猛性xxxx| 欧美成人在线免费视频| xxxxx成人.com| 国产亚洲精品久久久久久777| 精品一区二区三区四区在线| y97精品国产97久久久久久| 中文字幕精品在线视频| 国产精品久久999| 久久好看免费视频| 欧美日韩在线视频首页| 午夜精品久久久久久久久久久久| 久久精品在线视频| 欧美国产第一页| 91精品国产综合久久久久久蜜臀| 亚洲成人亚洲激情| 欧美丰满少妇xxxxx做受| 国产美女被下药99| 欧美成人高清视频| 国产亚洲人成网站在线观看| 亚洲第一区第二区| 国产91在线高潮白浆在线观看| 亚洲国产精品成人精品| 久久久久久成人精品| 欧洲成人免费视频| 日韩av在线最新| 精品国产91乱高清在线观看| 久久久久亚洲精品成人网小说| 中文字幕亚洲字幕| 国产精品1234| 91热福利电影| 亚洲精品www| 91精品视频专区| 91精品国产综合久久久久久久久| 国产精品777| 97国产精品免费视频| 精品二区三区线观看| 亚洲国产精品久久久久秋霞蜜臀| 45www国产精品网站| 久久精品中文字幕免费mv| 亚洲国产美女精品久久久久∴| 久久躁狠狠躁夜夜爽| 欧美极品美女视频网站在线观看免费| 福利二区91精品bt7086| 九九九久久国产免费| 久久国产精品久久久久久久久久| 亚洲高清久久久久久| 成人在线免费观看视视频| 欧美激情综合亚洲一二区| 操日韩av在线电影| 日韩一区二区在线视频| 欧美日韩中文字幕在线| 日韩av一区在线| 亚洲加勒比久久88色综合| 欧美限制级电影在线观看| 亚洲在线免费视频| 一区二区在线视频| 欧美电影免费观看高清| 国产精品美乳在线观看| 少妇高潮久久77777| 91视频国产精品| 欧美精品情趣视频| 日韩欧美国产一区二区| 亚洲第一中文字幕| 九九精品视频在线| 久久在线免费视频| 久久久久成人精品| 91久久久久久久一区二区| 国产一区二区三区在线免费观看| 日韩电影中文字幕一区| 亚洲欧洲日韩国产| 国产成人综合精品在线| 日韩免费av一区二区| 国产一区二区三区四区福利| 国产精品情侣自拍| 欧美日韩精品在线观看| 国产mv久久久| 国产精品视频永久免费播放| 亚洲一区二区三区在线免费观看| 青青草精品毛片| 18性欧美xxxⅹ性满足| 成人av色在线观看| 国产精品免费一区| 国产区亚洲区欧美区| 日韩在线精品一区| 91精品在线播放| 91精品国产综合久久久久久蜜臀| 欧美精品久久久久a| 久久久久久国产精品美女| 亚洲第一页中文字幕| 色诱女教师一区二区三区| 亚洲天堂av在线免费观看| 尤物99国产成人精品视频| 一区二区三区视频免费| 亚洲天堂久久av| 色一情一乱一区二区| 亚洲色图日韩av| 亚洲美女性生活视频| www.精品av.com| 亚洲国产美女久久久久| 欧美黄色小视频| 欧美激情视频免费观看| 亚洲女人被黑人巨大进入| 欧美精品在线观看91| 国产精品a久久久久久| 国产精品白丝av嫩草影院| 亚洲a级在线观看| 日韩av123| 深夜精品寂寞黄网站在线观看| 国产91在线高潮白浆在线观看| 亚洲欧洲在线播放| 欧美国产日韩二区| 成人精品一区二区三区电影免费| 国产精品一区二区在线| 亚洲天堂免费观看| 国产精品爽爽ⅴa在线观看| 亚洲精品国产精品久久清纯直播| 色老头一区二区三区| 韩剧1988在线观看免费完整版| 亚洲精品98久久久久久中文字幕| 国产亚洲精品久久久优势| 91精品国产网站| 97超级碰碰人国产在线观看| 91精品国产91久久久久久| 日本久久久久久久| 成人在线精品视频| 在线播放国产一区二区三区| 成人黄色免费网站在线观看| 国产69精品久久久久9999| 国产有码在线一区二区视频| 国产日本欧美一区二区三区在线| 久久成年人视频| 久久亚洲精品小早川怜子66| 久久久欧美精品| 日韩中文字幕在线免费观看| 日韩黄在线观看| 伊人久久大香线蕉av一区二区| 欧美日韩加勒比精品一区| 久久久噜久噜久久综合| 国产一区二区三区直播精品电影| 亚洲sss综合天堂久久| 欧美亚洲第一页| 欧美日韩国产在线看| 亚洲成色777777在线观看影院| 国产女同一区二区| 日韩一区二区三区xxxx| 狠狠躁18三区二区一区| 91av在线免费观看视频| 亚洲精品第一国产综合精品|