ES6模塊化

来源:http://www.cnblogs.com/yinxingen/archive/2017/12/10/8017713.html
-Advertisement-
Play Games

關於ES6模塊化 歷史上,JavaScript 一直沒有模塊(module)體系,無法將一個大程式拆分成互相依賴的小文件,再用簡單的方法拼裝起來。其他語言都有這項功能,比如 Ruby 的require、Python 的import,甚至就連 CSS 都有@import,但是 JavaScript 任 ...


關於ES6模塊化

歷史上,JavaScript 一直沒有模塊(module)體系,無法將一個大程式拆分成互相依賴的小文件,再用簡單的方法拼裝起來。其他語言都有這項功能,比如 Ruby 的require、Python 的import,甚至就連 CSS 都有@import,但是 JavaScript 任何這方面的支持都沒有,這對開發大型的、複雜的項目形成了巨大障礙。

在nodeJS中,有模塊化的方法,使用CommonJS規範可以做到模塊化,也就是說,只有在用js進行後端node開發的時候,才能使用模塊化,前端js依然不行

在前端我們可以使用requireJS,seaJS來實現模塊化,但是requireJS也是通過對script標簽進行非同步導入的方式來進行,並不是js里自帶的語法

我們也可以使用webpack工具來進行模塊化打包,是因為webpack跑在nodeJS中,說到底還是nodeJS中的模塊化

但是在ES6中,我們第一次在js語法中加入了模塊化的東西,目前很多瀏覽器都不支持,所以說還需要編譯

ES6模塊化的規範

模塊功能主要由兩個命令構成:export和import。export命令用於規定模塊的對外介面,import命令用於輸入其他模塊提供的功能。

  1. 暴露

可以export直接暴露出某些對象,可以暴露多個:

    //暴露多個介面 在定義的時候暴露
    export let str = 'abcd'
    export  let fn = function(){
        console.log('fn')
    }
    export let person = {
        name:'二狗'
    }

    //暴露多個介面,在{}里放入要暴露的對象
    export {str,fn,person}
因為直接暴露的對象在引入的時候名字不能改變,可能會導致在引入的模塊中造成命名衝突
可以在暴露的時候通過as來定義別名
    export {str as a_str,fn as a_fn,person as a_person}
在暴露對象的時候,如果只有一個,可以default暴露,在引入的時候叫啥都行,也不用加{}
    export default fn
default只能暴露一個東西,如果我們有一個是defualt暴露的,還有幾個是具名暴露
    export default str
    export {fn,person}
引入:
    import abc,{fn,person} from './modules/module_a'//abc就是上面的str
  1. 導入

    如果被引入的模塊沒有暴露,只是一段邏輯代碼需要在引入模塊里運行的話

    import './modules/empty'
如果要導入某一個模塊中暴露的一些對象的話,註意,不一定非要把其暴露的模塊全部引入,導出的對象的名字不能錯
    import {str,fn,person} from './modules/module_a.js'
    console.log(str,person)
    fn()
在引入模塊中暴露的介面的時候,很可能會產生命名衝突,依賴於在暴露的時候定義別名的話,也不是很安全,所以最好在引入的時候命名別名
    import {str as a_str,fn as a_fn,person as a_person} from './modules/module_a.js'
如果要引入的模塊暴露出來的對象有很多,我們在引入的時候可以放入到一個對象中去使用:
A對象不需要自己定義,引入的時候會自動創建
    import * as A from './modules/module_a'
    console.log(A)

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 視圖是一種虛表,使用CREATE VIEW語句來定義視圖,該視圖是基於一個或多個表或視圖的邏輯表。一個視圖本身不包含任何數據, 視圖所基於的表稱為基表。 視圖就相當於一條select 語句,定義了一個視圖就是定義了一個sql語句, 視圖不占空間,使用視圖不會提高性能,但是能簡化sql語句 。 創建視 ...
  • 最近在看SDWebImage源碼,碰到一些比較繞的問題,理解了很久,然後在網上查了些的資料,才算是有了一些理解。在此記錄一下。 源碼如下: block會copy要在block中使用的實變數,而copy會是變數的retainCount + 1,如若在不註意很容易造成迴圈引用。而所謂的迴圈引用的本質就是 ...
  • 最近突然心血如潮開始學了Android破解,初入門,便是將經驗記錄下來。 準備工作: 1、一個登錄簡單APP 在我們破解之前,我們需要做一個簡單的登錄APP,輸入相應的賬號與密碼便是彈出登錄成功的對話框,賬號與密碼不匹配的話則是彈出登錄失敗的對話框,如下圖 由於我之前已經寫了一篇關於製作登錄界面的簡 ...
  • PS:我們在做安卓程式的時候,免不了會做一些圖形,自己可以選擇自定義view ,就是用Canvas畫,也可以用寫好的jar包,就是achartengine.jar,使用jar包的好處就快速繪製圖形,不用我們計算坐標等,計算坐標就會和數學結合,通過sin,cos等來計算,遇到3維那就更麻煩了,就像Op ...
  • PS:SharedPreferences只要稍微學過一點就會用,他本身通過創建一個Editor對象,來存儲提交,而editor可以存的格式為 他裡面可以存一個Set<String> HashSet是Java中非常常用的數據結構對象,HashSet是通過HashMap實現的,TreeSet是通過Tre ...
  • 一、概述 Glide是一個在Android端非常好的圖片緩衝工具,總體上來說,他有以下優點 使用簡單 自適應程度高 支持常見的圖片格式,如jpg,png等 支持多種數據源,網路,本地,資源,Assets等 高效的緩存策略,支持Memory和Disk圖片緩存策略,預設Bitmap格式採用RGB_565 ...
  • 時間:2017年12月10日 21:52:59 用途:此文章用於個人總結 css筆記1.CSS全稱為"層疊樣式表(Cascading Style Sheets)"2.CSS樣式的語法: 選擇符{屬性:值}3.CSS樣式代碼插入的三種形式:內聯/嵌入/外部 內聯式:就是把代碼寫在html標簽的行間樣式 ...
  • 萬事開頭難,一個好的Hello World程式可以節省我們好多的學習時間,幫助我們快速入門。Hello World程式之所以是入門必讀必會,就是因為其代碼量少,簡單易懂。但我覺得,還應該做到功能豐富,涉及的知識點多。這樣才是一個好的初學者入門指引程式。 之所以選擇Vue,不僅因為其流行,還因為其輕量 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...