亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

TypeScript模塊與命名空間的關(guān)系和使用方法

 更新時(shí)間:2023年03月09日 10:20:26   作者:劍九 六千里  
在TypeScript中就像在EC5中一樣,任何包含頂級import或export的文件都被認(rèn)為是一個(gè)模塊,下面這篇文章主要給大家介紹了關(guān)于如何在TypeScript使用模塊與命名空間以及注意事項(xiàng)的相關(guān)資料,需要的朋友可以參考下

一、模塊

1. 全局模塊

在默認(rèn)情況下,當(dāng)你開始在一個(gè)新的 TypeScript 文件中寫下代碼時(shí),它處于全局命名空間中

在全局變量空間是危險(xiǎn)的,因?yàn)樗麜c文件內(nèi)的代碼命名沖突。我們推薦使用下文中將要提到的文件模塊

示例:

// 由于此時(shí)默認(rèn)為全局變量
// 因此會報(bào)錯(cuò):無法重新聲明塊范圍變量“name”。ts(2451)
let name = '張三';

2. 文件模塊

文件模塊也被稱為外部模塊。如果在你的 TypeScript 文件的根級別位置含有 import 或者 export,那么它會在這個(gè)文件中創(chuàng)建一個(gè)本地的作用域

模塊是 TS 中外部模塊的簡稱,側(cè)重于代碼的復(fù)用

模塊在自身的作用域里執(zhí)行,而不是在全局作用域里

一個(gè)模塊里的變量、函數(shù)、類等在外部是不可見的,除非將其導(dǎo)出

如果想要使用一個(gè)模塊里導(dǎo)出的變量,則需要導(dǎo)入

示例:

// 此時(shí)a,b和默認(rèn)導(dǎo)出的name可以在其他文件導(dǎo)入使用
// c由于未導(dǎo)出,因此在其他文件導(dǎo)入c時(shí)會報(bào)錯(cuò)
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:這是一個(gè)好的實(shí)驗(yàn),已經(jīng)被 ES 模塊替代
  • ES 模塊:它并沒有準(zhǔn)備好,瀏覽器暫時(shí)還不支持
  • 使用 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ù),多個(gè)文件導(dǎo)出同樣的命名是被允許的文件模塊是獨(dú)立的,互相之間不影響命名空間全局具有唯一性,導(dǎo)出的名稱不能重復(fù)

補(bǔ)充:同一模塊下命名空間一致會合并;不同模塊下同名命名空間不會合并

到此這篇關(guān)于TypeScript模塊與命名空間的關(guān)系和使用方法的文章就介紹到這了,更多相關(guān)TypeScript模塊與命名空間內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • KnockoutJs快速入門教程

    KnockoutJs快速入門教程

    這篇文章主要為大家分享了KnockoutJs快速入門教程,了解KnockoutJs到底是什么?如何使用KnockoutJS中的data-bind語法來將模型數(shù)據(jù)綁定到DOM元素中,感興趣的小伙伴們可以參考一下
    2016-05-05
  • JavaScript獲取本機(jī)IP地址三種常用方式

    JavaScript獲取本機(jī)IP地址三種常用方式

    在瀏覽器中使用JavaScript獲取本機(jī)IP地址是不可行的,因?yàn)闉g覽器的安全策略禁止JavaScript訪問這樣的信息,這篇文章主要給大家介紹了關(guān)于JavaScript獲取本機(jī)IP地址的三種常用方式,需要的朋友可以參考下
    2023-12-12
  • JS中setTimeout()的用法詳解

    JS中setTimeout()的用法詳解

    setTimeout( ) 是屬于 window 的 method, 但我們都是略去 window 這頂層物件名稱, 這是用來設(shè)定一個(gè)時(shí)間, 時(shí)間到了, 就會執(zhí)行一個(gè)指定的 method
    2013-04-04
  • js實(shí)現(xiàn)公告自動(dòng)滾動(dòng)

    js實(shí)現(xiàn)公告自動(dòng)滾動(dòng)

    這篇文章主要為大家詳細(xì)介紹了js實(shí)現(xiàn)公告自動(dòng)滾動(dòng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-05-05
  • 輕松掌握J(rèn)avaScript狀態(tài)模式

    輕松掌握J(rèn)avaScript狀態(tài)模式

    這篇文章主要幫助大家輕松掌握J(rèn)avaScript狀態(tài)模式,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-09-09
  • parabola.js拋物線與加入購物車效果的示例代碼

    parabola.js拋物線與加入購物車效果的示例代碼

    本篇文章主要介紹了parabola.js拋物線與加入購物車效果的示例代碼,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-10-10
  • js通過canvas生成圖片縮略圖

    js通過canvas生成圖片縮略圖

    對于生成縮略圖一般做法是通過后端語言php等來生成,但是為了給服務(wù)器減壓,我們或許可以從前端來著手,先生成好不同尺寸的縮略圖,傳給后端,而后端只需要將前端傳過來的圖片進(jìn)行存儲就好了
    2020-10-10
  • 基于BootStrap Metronic開發(fā)框架經(jīng)驗(yàn)小結(jié)【九】實(shí)現(xiàn)Web頁面內(nèi)容的打印預(yù)覽和保存操作

    基于BootStrap Metronic開發(fā)框架經(jīng)驗(yàn)小結(jié)【九】實(shí)現(xiàn)Web頁面內(nèi)容的打印預(yù)覽和保存操作

    本篇文章主要介紹如何實(shí)現(xiàn)Web頁面內(nèi)容的打印預(yù)覽和保存操作的相關(guān)知識,感興趣的朋友一起學(xué)習(xí)吧
    2016-05-05
  • Webkit的跨域安全問題說明

    Webkit的跨域安全問題說明

    在使用try catch處理iframe跨域產(chǎn)生的異常時(shí),chrome和safari瀏覽器似乎不能正常運(yùn)作:他們直接拋出了錯(cuò)誤而沒有拋出可供JS截獲的異常。
    2011-09-09
  • 關(guān)于document.cookie的使用javascript

    關(guān)于document.cookie的使用javascript

    設(shè)置cookie 每個(gè)cookie都是一個(gè)名/值對,可以把下面這樣一個(gè)字符串賦值給document.cookie:
    2008-04-04

最新評論