查看: 89|回覆: 0

TypeScript 命名空间-Namespace

[複製鏈接]

5

主題

0

回帖

0

積分

热心网友

金币
0
閲讀權限
220
精華
0
威望
0
贡献
0
在線時間
0 小時
註冊時間
2012-2-22
發表於 2021-1-11 10:26:00 | 顯示全部樓層 |閲讀模式

TypeScript 通过 tsc 编译成 JavaScript 时,用的是 var 全局变量,var 用多了会造成全局变量污染,为了解决这个问题,使用命名空间。

# 生成 package.json 文件
npm init -y
# 生成 tsconfig.json文件
tsc -init

命名空间

namespace Home {
  class Header {
    constructor() {
      const elem = document.createElement("div");
      elem.innerText = "This is Header";
      document.body.appendChild(elem);
    }
  }

  class Content {
    constructor() {
      const elem = document.createElement("div");
      elem.innerText = "This is Content";
      document.body.appendChild(elem);
    }
  }

  class Footer {
    constructor() {
      const elem = document.createElement("div");
      elem.innerText = "This is Footer";
      document.body.appendChild(elem);
    }
  }

  export class Page {
    constructor() {
      new Header();
      new Content();
      new Footer();
    }
  }
}

使用:

new Home.Page();

只能通过 Home 访问 Page,其他变量无法访问,避免了全局变量的污染。
这就是 TypeScript 给我们提供的类似模块化开发的语法,它的好处就是让全局变量减少了很多,实现了基本的封装,减少了全局变量的污染。

多命名空间(组件化)

namespace Components {
  export class Header {
    constructor() {
      const elem = document.createElement("div");
      elem.innerText = "This is Header";
      document.body.appendChild(elem);
    }
  }

  export class Content {
    constructor() {
      const elem = document.createElement("div");
      elem.innerText = "This is Content";
      document.body.appendChild(elem);
    }
  }

  export class Footer {
    constructor() {
      const elem = document.createElement("div");
      elem.innerText = "This is Footer";
      document.body.appendChild(elem);
    }
  }
}
namespace Home {
  export class Page {
    constructor() {
      new Components.Header();
      new Components.Content();
      new Components.Footer();
    }
  }
}

为了便利,需要把这两个 ts 文件编译输出成一个 js 文件,参考:TypeScript 多个文件编译成一个 js 文件

子命名空间


namespace Components {
  export namespace SubComponents {
    export class Test {}
  }

  //someting ...
}

相关文章:
TypeScript 多个文件编译成一个 js 文件
参考:
技术胖——TypeScript从入门到精通(22. 初识命名空间-Namespace)
技术胖——TypeScript从入门到精通(23. 深入命名空间-Namespace)



来源:https://www.cnblogs.com/xch-jiang/p/14260159.html
回覆

使用道具 舉報

您需要登錄後才可以回帖 登錄 | 立即注册

本版積分規則

相关侵权、举报、投诉及建议等,请发 E-mail:qiongdian@foxmail.com

Powered by Discuz! X5.0 © 2001-2026 Discuz! Team.

在本版发帖返回顶部