成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

面試官:說說對 TypeScript 中命名空間與模塊的理解?區別?

開發 后端
TypeScript 與ECMAScript 2015 一樣,任何包含頂級 import 或者 export 的文件都被當成一個模塊。

[[423398]]

一、模塊

TypeScript 與ECMAScript 2015 一樣,任何包含頂級 import 或者 export 的文件都被當成一個模塊

相反地,如果一個文件不帶有頂級的import或者export聲明,那么它的內容被視為全局可見的

例如我們在在一個 TypeScript 工程下建立一個文件 1.ts,聲明一個變量a,如下:

  1. const a = 1 

然后在另一個文件同樣聲明一個變量a,這時候會出現錯誤信息

提示重復聲明a變量,但是所處的空間是全局的

如果需要解決這個問題,則通過import或者export引入模塊系統即可,如下:

  1. const a = 10; 
  2.  
  3. export default a 

在typescript中,export關鍵字可以導出變量或者類型,用法與es6模塊一致,如下:

  1. export const a = 1 
  2. export type Person = { 
  3.     name: String 

通過import 引入模塊,如下:

  1. import { a, Person } from './export'

二、命名空間

命名空間一個最明確的目的就是解決重名問題

命名空間定義了標識符的可見范圍,一個標識符可在多個名字空間中定義,它在不同名字空間中的含義是互不相干的

這樣,在一個新的名字空間中可定義任何標識符,它們不會與任何已有的標識符發生沖突,因為已有的定義都處于其他名字空間中

TypeScript 中命名空間使用 namespace 來定義,語法格式如下:

  1. namespace SomeNameSpaceName { 
  2.    export interface ISomeInterfaceName {      }   
  3.    export class SomeClassName {      }   

以上定義了一個命名空間 SomeNameSpaceName,如果我們需要在外部可以調用 SomeNameSpaceName 中的類和接口,則需要在類和接口添加 export 關鍵字

使用方式如下:

  1. SomeNameSpaceName.SomeClassName 

命名空間本質上是一個對象,作用是將一系列相關的全局變量組織到一個對象的屬性,如下:

  1. namespace Letter { 
  2.   export let a = 1; 
  3.   export let b = 2; 
  4.   export let c = 3; 
  5.   // ... 
  6.   export let z = 26; 

編譯成js如下:

  1. var Letter; 
  2. (function (Letter) { 
  3.     Letter.a = 1; 
  4.     Letter.b = 2; 
  5.     Letter.c = 3; 
  6.     // ... 
  7.     Letter.z = 26; 
  8. })(Letter || (Letter = {})); 

三、區別

命名空間是位于全局命名空間下的一個普通的帶有名字的 JavaScript 對象,使用起來十分容易。但就像其它的全局命名空間污染一樣,它很難去識別組件之間的依賴關系,尤其是在大型的應用中

像命名空間一樣,模塊可以包含代碼和聲明。不同的是模塊可以聲明它的依賴

在正常的TS項目開發過程中并不建議用命名空間,但通常在通過 d.ts 文件標記 js 庫類型的時候使用命名空間,主要作用是給編譯器編寫代碼的時候參考使用

參考文獻

https://www.tslang.cn/docs/handbook/modules.html

https://www.tslang.cn/docs/handbook/namespaces.html

 

https://www.tslang.cn/docs/handbook/namespaces-and-modules.html

 

責任編輯:武曉燕 來源: JS每日一題
相關推薦

2021-06-30 07:19:36

React事件機制

2021-05-31 10:35:34

TCPWebSocket協議

2021-06-04 07:55:30

Node Fs 操作

2021-07-12 08:35:24

組件應用場景

2021-06-08 08:33:23

NodeStream數據

2021-06-07 09:41:48

NodeBuffer 網絡協議

2021-07-07 08:36:45

React應用場景

2021-09-07 08:33:27

JavaScript TypeScript 函數

2021-06-10 07:51:07

Node.js循環機制

2021-06-03 08:14:01

NodeProcessJavaScript

2021-07-13 07:52:03

ReactHooks組件

2021-07-08 06:51:29

React函數組件

2021-10-29 09:40:21

設計模式軟件

2021-07-29 07:55:20

React Fiber架構引擎

2021-09-06 10:51:27

TypeScriptJavaScript

2025-03-07 08:44:47

Typescriptiinterfacetype

2021-09-08 07:49:34

TypeScript 泛型場景

2020-08-03 07:38:12

單例模式

2021-11-25 10:18:42

RESTfulJava互聯網

2021-10-15 09:53:12

工具
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 精品成人免费视频 | 自拍偷拍3p | 国产成人精品视频在线观看 | av资源中文在线天堂 | 精品乱码一区二区三四区视频 | 欧美白人做受xxxx视频 | 亚洲一区二区在线播放 | 亚洲视频在线免费观看 | 黄视频网址 | 亚洲精品久久久久国产 | 成人免费毛片在线观看 | 蜜桃视频在线观看免费视频网站www | 国产99久久精品一区二区永久免费 | 欧美日高清视频 | 日韩免费av网站 | 青青草一区二区 | 亚洲第一色av | 99久久精品免费看国产四区 | 亚洲天堂中文字幕 | 青青激情网 | 日韩一区二区久久 | 日韩精品二区 | 91色站 | 国产精品无码久久久久 | 在线播放一区二区三区 | 精品国产乱码久久久久久a丨 | 91视频在线看 | 亚洲资源在线 | 日韩视频中文字幕 | 成人精品鲁一区一区二区 | 欧美日韩在线观看视频网站 | 99久久久久久久 | 国产成在线观看免费视频 | 草逼网站 | 精品在线 | 亚洲激情一区二区三区 | 台湾佬久久 | 欧美专区在线视频 | 久久精品二区 | 亚洲aⅴ一区二区 | 精品久久久久国产 |