TypeScript中命名空間與模塊化詳情
一、模塊
TypeScript
與ECMAScript
2015 一樣,任何包含頂級 import
或者 export
的文件都被當成一個模塊
相反地,如果一個文件不帶有頂級的import
或者export
聲明,那么它的內(nèi)容被視為全局可見的
例如我們在在一個 TypeScript
工程下建立一個文件 1.ts
,聲明一個變量a
,如下:
const a = 1
然后在另一個文件同樣聲明一個變量a
,這時候會出現(xiàn)錯誤信息
提示重復聲明a
變量,但是所處的空間是全局的
如果需要解決這個問題,則通過import
或者export
引入模塊系統(tǒng)即可,
如下:
const a = 10; export default a
在typescript
中,export
關(guān)鍵字可以導出變量或者類型,用法與es6
模塊一致,
如下:
export const a = 1 export type Person = { name: String }
通過import
引入模塊,如下:
import { a, Person } from './export';
二、命名空間
命名空間一個最明確的目的就是解決重名問題
命名空間定義了標識符的可見范圍,一個標識符可在多個名字空間中定義,它在不同名字空間中的含義是互不相干的
這樣,在一個新的名字空間中可定義任何標識符,它們不會與任何已有的標識符發(fā)生沖突,因為已有的定義都處于其他名字空間中
TypeScript
中命名空間使用 namespace
來定義,語法格式如下:
namespace SomeNameSpaceName { export interface ISomeInterfaceName { } export class SomeClassName { } }
以上定義了一個命名空間 SomeNameSpaceName
,如果我們需要在外部可以調(diào)用 SomeNameSpaceName
中的類和接口,則需要在類和接口添加 export
關(guān)鍵字
使用方式如下:
SomeNameSpaceName.SomeClassName
命名空間本質(zhì)上是一個對象,作用是將一系列相關(guān)的全局變量組織到一個對象的屬性,如下:
namespace Letter { export let a = 1; export let b = 2; export let c = 3; // ... export let z = 26; }
編譯成js
如下:
var Letter; (function (Letter) { Letter.a = 1; Letter.b = 2; Letter.c = 3; // ... Letter.z = 26; })(Letter || (Letter = {}));
三、區(qū)別
- 命名空間是位于全局命名空間下的一個普通的帶有名字的 JavaScript 對象,使用起來十分容易。但就像其它的全局命名空間污染一樣,它很難去識別組件之間的依賴關(guān)系,尤其是在大型的應用中
- 像命名空間一樣,模塊可以包含代碼和聲明。 不同的是模塊可以聲明它的依賴
- 在正常的TS項目開發(fā)過程中并不建議用命名空間,但通常在通過 d.ts 文件標記 js 庫類型的時候使用命名空間,主要作用是給編譯器編寫代碼的時候參考使用
到此這篇關(guān)于TypeScript中命名空間與模塊化詳情的文章就介紹到這了,更多相關(guān)TypeScript命名空間內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
IE8 內(nèi)存泄露(內(nèi)存一直增長 )的原因及解決辦法
最近開發(fā)的時候?qū)撁媸褂昧硕〞r的局部更新,結(jié)果在ie6,7和Firefox下,一切正常,而在ie8下過上幾個小時就瀏覽器就崩潰了,顯示是內(nèi)存溢出,下面由腳本之家小編給大家介紹ie8下內(nèi)存一直增長內(nèi)存泄漏的原因及解決辦法,需要的朋友一起學習吧2016-04-04JavaScript實現(xiàn)tab欄切換的幾種常用方法
這篇文章主要給大家介紹了關(guān)于JavaScript實現(xiàn)tab欄切換的幾種常用方法,在Web開發(fā)中Tab切換是一個常見的功能,它允許用戶在不同的頁面部分之間進行切換,需要的朋友可以參考下2023-12-12bootstrap weebox 支持ajax的模態(tài)彈出框
本篇介紹的bootstrap weebox(支持ajax的模態(tài)彈出框),歷經(jīng)多次修改,目前版本已經(jīng)穩(wěn)定,整合了bootstrap的響應式,界面簡單,功能卻無比豐富,支持ajax、圖片預覽等等2017-02-02uniapp開發(fā)微信小程序主包太大和vendor.js過大無法打包問題解決
最近工作一直在uniapp開發(fā)小程序這一塊,相信很多開發(fā)者都遇到過代碼體積太大無法打包的問題,這篇文章主要給大家介紹了關(guān)于uniapp開發(fā)微信小程序主包太大和vendor.js過大無法打包問題的解決辦法,需要的朋友可以參考下2023-11-11基于javascript實現(xiàn)彩票隨機數(shù)生成(升級版)
這篇文章主要為大家詳細介紹了基于javascript實現(xiàn)彩票隨機數(shù)生成的相關(guān)資料,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-01-01