真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

NodeJS中怎么實(shí)現(xiàn)循環(huán)引用

這篇文章將為大家詳細(xì)講解有關(guān)NodeJS中怎么實(shí)現(xiàn)循環(huán)引用,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個(gè)參考,希望大家閱讀完這篇文章后對(duì)相關(guān)知識(shí)有一定的了解。

員工經(jīng)過長(zhǎng)期磨合與沉淀,具備了協(xié)作精神,得以通過團(tuán)隊(duì)的力量開發(fā)出優(yōu)質(zhì)的產(chǎn)品。成都創(chuàng)新互聯(lián)堅(jiān)持“專注、創(chuàng)新、易用”的產(chǎn)品理念,因?yàn)椤皩W⑺詫I(yè)、創(chuàng)新互聯(lián)網(wǎng)站所以易用所以簡(jiǎn)單”。公司專注于為企業(yè)提供做網(wǎng)站、網(wǎng)站制作、微信公眾號(hào)開發(fā)、電商網(wǎng)站開發(fā),小程序設(shè)計(jì),軟件按需網(wǎng)站制作等一站式互聯(lián)網(wǎng)企業(yè)服務(wù)。

場(chǎng)景復(fù)現(xiàn)

出現(xiàn)問題場(chǎng)景比較簡(jiǎn)單,一共四個(gè)類:

  • parent.ts

  • child.ts

  • child_2.ts

  • util.ts

export abstract class Parent {

 abstract hello(): string;
}
import {Parent} from "./parent";

export class Child extends Parent {

 hello(): string {
  return "child";
 }

}
import {Child} from "./child";

export class Util {

 static useChildInSameCase(): string {
  let child: Child;
  return child.hello();
 }
}
import {Parent} from "./parent";

export class Child_2 extends Parent {

 hello(): string {
  return "child_2";
 }

}

這個(gè)時(shí)候我們?nèi)?gòu)造一個(gè)Child類:

import {Child} from "./child";

console.log(new Child().func());

就會(huì)直接報(bào)錯(cuò)了:

class Child_2 extends parent_1.Parent {
^

TypeError: Class extends value undefined is not a function or null

#尋找原因

說的是這個(gè)父類是一個(gè)undefined,很明顯就是沒有初始化。

一開始我覺得很奇怪,明明在child_2這個(gè)文件里已經(jīng)import了parent,為什么會(huì)是undefined呢?后來debug查了一下代碼的堆棧,恍然大悟:

入口文件->child.ts->parent.ts->util.ts->child_2.ts->parent.ts

很明顯這里存在著一個(gè)循環(huán)引用,當(dāng)我們?cè)诩虞dchild_2.ts這個(gè)文件的時(shí)候,parent.ts還處在未加載完的狀態(tài)。

我們可以去 官網(wǎng)看一下node中是如何處理循環(huán)引用的 。

通過官網(wǎng)我們可以知道,對(duì)于這樣的循環(huán)引用,在child_2.ts加載parent.ts的時(shí)候,會(huì)去緩存中尋找,而由于parent.ts還未加載完成,所以緩存中會(huì)是一個(gè)空對(duì)象了,官網(wǎng)中用的語句是 an unfinished copy of the a.js 。

解決方案

知道原因之后,解決方案也就變得清晰了起來,一句話搞定,將parent.ts中的import語句放在后面:

export abstract class Parent {

  abstract hello(): string;

  func(): string {
    return Util.useChildInSameCase();
  }
}

import {Util} from "./util";

這樣在加載parent.ts的時(shí)候,就會(huì)先export對(duì)象,然后再import所需要的util.ts了。

關(guān)于NodeJS中怎么實(shí)現(xiàn)循環(huán)引用就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。


文章題目:NodeJS中怎么實(shí)現(xiàn)循環(huán)引用
當(dāng)前路徑:http://weahome.cn/article/gdjsgp.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部