ECMAScript6.0新特性介紹第七篇
在這篇部落格中我將介紹ES6的模組化。在ES6當中一個JS檔案就是一個模組,如果想要實現模組與模組之間進行訪問。就要用到ES6的兩個模組化命令:export和import。export關鍵字用於使用者自定義模組的對外介面,而import命令輸入其他模組的功能。關於import和export的使用參考如下程式碼:
- 使用export匯出單個變數。
//student.js
let name= 'zhangsan';
let age = '19';
let sex= 'male';
export {name, age, sex};
- 使用import命令獲取其他模組匯出的變數
import {name, age, sex} from './student';
console.log(name+':'+age+':'+sex);//輸出zhangsan:19:male
//你也可以給匯入的變數起別名
import { name as nickname} from './student';
console.log(nickname);//輸出zhangsan
- 使用export匯出函式
// math.js 以下函式的作用是將傳入的一組引數乘以二倍後返回。
export function double(...args) {
return args.map(x => x * 2);
}
//以下函式的作用是將傳入的引數進行求和。
export function sum(...args) {
let sum = args.reduce((currentSum, item, index) => currentSum + item);
return sum;
}
- 使用import引入其他模組匯出的函式
import { double, sum} from './math';
console.log(double(1,2,3,4,5,6,7,8,9,10));//輸出:2,4,6,8,10,12,14,16,18,20
console.log(sum(1,2,3,4,5,6,7,8,9,10));//輸出:55
- module命令:可以取代import語句,達到整體輸入模組的作用。
module math from './math';
console.log(math.double(1,2,3,4,5,6,7,8,9,10));//輸出:2,4,6,8,10,12,14,16,18,20
console.log(math.sum(1,2,3,4,5,6,7,8,9,10));//輸出:55
- export default命令:為載入模組指定預設輸出
// hello.js
export default function () {
console.log('weclome to the imooc!');
}
//其他模組載入hello.js時可以指定任意名稱。
import imooc from './hello';
imooc(); // 輸出'weclome to the imooc!
關於ES6的模組化就介紹到這裡。
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/2508/viewspace-2800556/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- TiDB 5.0.0新特性介紹TiDB
- [譯] Chrome 71 新特性介紹Chrome
- AnalyticDB for PostgreSQL 6.0 新特性介紹SQL
- Apache Cassandra 4.0新特性介紹Apache
- Angular 8的新特性介紹Angular
- webpack4新特性介紹Web
- 【IDL】IDL 8.4新特性介紹
- JavaScript 6 的新特性介紹JavaScript
- React v16.6 新特性介紹React
- Redis4.0的新特性介紹Redis
- Dash 2.16版本新特性介紹
- Dash 2.17版本新特性介紹
- SQL?Server新特性SequenceNumber用法介紹YTZBSQLServer
- Flutter 3.7 新特性:介紹後臺isolate通道Flutter
- MyRocksTTL特性介紹
- Jetbrains CLion特性介紹AI
- Jetbrains pycharm特性介紹AIPyCharm
- Jetbrains datagrip特性介紹AI
- Jetbrains goland特性介紹AIGoLand
- Zookeeper 節點特性介紹
- MySQL 8.0 新增特性介紹MySql
- Kyma Application Connectivity 特性介紹APP
- 【劉文彬】 EOS1.1版本新特性介紹
- Docker的原理及特性介紹Docker
- 【kingsql分享】Oracle Database 19c的各種新特性介紹SQLOracleDatabase
- SQL Server 2022 AlwaysOn新特性之包含可用性組介紹SQLServer
- 【kingsql分享】Oracle Database 20c 十大新特性介紹SQLOracleDatabase
- ES10(ES2019)新特性介紹和程式碼例項
- Golang Agent 可觀測性的全面升級與新特性介紹Golang
- 螞蟻金服 SOFAArk 0.6.0 新特性介紹 | 模組化開發容器
- 開工大吉:Oracle 18c已經發布及新特性介紹Oracle
- 微軟介紹Edge瀏覽器新特性,支援筆記同步DROP等微軟瀏覽器筆記
- ES2015新特性簡介
- K8s的介紹和特性K8S
- BootstrapBlazor 智慧生成神器(一)AutoGenerateColumnAttribute 特性介紹bootBlazor
- CSS的特性之層疊性介紹CSS
- OneAuth 3月釋出: Cloud UD 特性介紹Cloud
- SAP UI5 Decision Table 的特性介紹UI