TypeScript模塊與命名空間的關(guān)系和使用方法
一、模塊
1. 全局模塊
在默認(rèn)情況下,當(dāng)你開始在一個新的 TypeScript 文件中寫下代碼時,它處于全局命名空間中
在全局變量空間是危險的,因為他會與文件內(nèi)的代碼命名沖突。我們推薦使用下文中將要提到的文件模塊
示例:
// 由于此時默認(rèn)為全局變量 // 因此會報錯:無法重新聲明塊范圍變量“name”。ts(2451) let name = '張三';
2. 文件模塊
文件模塊也被稱為外部模塊。如果在你的 TypeScript 文件的根級別位置含有 import 或者 export,那么它會在這個文件中創(chuàng)建一個本地的作用域
模塊是 TS 中外部模塊的簡稱,側(cè)重于代碼的復(fù)用
模塊在自身的作用域里執(zhí)行,而不是在全局作用域里
一個模塊里的變量、函數(shù)、類等在外部是不可見的,除非將其導(dǎo)出
如果想要使用一個模塊里導(dǎo)出的變量,則需要導(dǎo)入
示例:
// 此時a,b和默認(rèn)導(dǎo)出的name可以在其他文件導(dǎo)入使用
// c由于未導(dǎo)出,因此在其他文件導(dǎo)入c時會報錯
export const a = 1;
export const b = 2;
const c = 3;
export default { name: 'Tom' }
// 導(dǎo)入
// import { a, b } from './xxx.ts'
3. 模塊規(guī)范
- AMD:不要使用它,它僅能在瀏覽器工作
- SystemJs:這是一個好的實(shí)驗,已經(jīng)被 ES 模塊替代
- ES 模塊:它并沒有準(zhǔn)備好,瀏覽器暫時還不支持
- 使用 module: commonjs 來替代這些模塊,commonjs在node和瀏覽器中都支持
二、命名空間
在代碼量較大的情況下,為了避免命名空間沖突,可以將相似的函數(shù)、類、接口防止在命名空間內(nèi)
命名空間可以將代碼包裹起來,只對外暴露需要在外部訪問的對象,命名空間內(nèi)通過 export 向外導(dǎo)出
命名空間是內(nèi)部模塊,主要用于組織代碼,避免命名沖突
示例:
// 注意:此處可以在當(dāng)前文件直接使用,也可以在其他文件導(dǎo)入使用
export namespace person {
class Woman { };
// 此處加了export關(guān)鍵字才會被導(dǎo)出,否則則為私有
export class Man {
eat() { return '吃飯' }
}
}
export namespace animal {
class Bird { };
// 此處加了export關(guān)鍵字才會被導(dǎo)出,否則則為私有
export class Tiger {
eat() { return '吃肉' }
}
// 命名空間嵌套命名空間
export namespace monkeyArea {
export class Monkey {
eat() { return '吃水果' }
}
}
}
let p = new person.Man();
console.log(p.eat()); // 吃飯
let t = new animal.Tiger();
console.log(t.eat()); // 吃肉
let m = new animal.monkeyArea.Monkey();
console.log(m.eat()); // 吃水果
三、文件模塊和命名空間的關(guān)系
文件模塊可以重復(fù),多個文件導(dǎo)出同樣的命名是被允許的文件模塊是獨(dú)立的,互相之間不影響命名空間全局具有唯一性,導(dǎo)出的名稱不能重復(fù)
補(bǔ)充:同一模塊下命名空間一致會合并;不同模塊下同名命名空間不會合并
到此這篇關(guān)于TypeScript模塊與命名空間的關(guān)系和使用方法的文章就介紹到這了,更多相關(guān)TypeScript模塊與命名空間內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
js實(shí)現(xiàn)控制文件拖拽并獲取拖拽內(nèi)容功能
本片文章主要給大家分享了用JS寫出控制文件拖拽并獲取拖拽內(nèi)容功能實(shí)現(xiàn)過程,以及代碼分享,有興趣的一起學(xué)習(xí)下。2018-02-02
TypeScript中交叉類型和聯(lián)合類型的區(qū)別詳解
聯(lián)合類型(Union Types)和交叉類型(Intersection Types)是 TypeScript 中的兩種高級類型,它們都用于組合多個類型并生成新的類型,但它們兩者之間的用法不一樣,本文小編就給大家講講TypeScript中交叉類型和聯(lián)合類型的區(qū)別,需要的朋友可以參考下2023-09-09
前端JavaScript實(shí)現(xiàn)文件壓縮的全面優(yōu)化指南
JavaScript文件大小直接影響網(wǎng)頁加載速度和用戶體驗,本文將詳細(xì)介紹從基礎(chǔ)到高級的各種JavaScript壓縮優(yōu)化技術(shù),小伙伴可以根據(jù)需求進(jìn)行選擇2025-04-04
JavaScript實(shí)現(xiàn)循環(huán)輪播圖
這篇文章主要為大家詳細(xì)介紹了JavaScript實(shí)現(xiàn)循環(huán)輪播圖,文中示例代碼介紹的非常詳細(xì),具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-04-04
Javascript柯里化實(shí)現(xiàn)原理及作用解析
這篇文章主要介紹了Javascript柯里化實(shí)現(xiàn)原理及作用解析,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下2020-10-10
在JavaScript中查找字符串中最長單詞的三種方法(推薦)
這篇文章主要介紹了在JavaScript中查找字符串中最長單詞的三種方法,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-01-01

