官术网_书友最值得收藏!

Modules

ECMAScript 2015 has introduced built-in modules. The features of modules are as follows:

  • Each module is defined in its own file.
  • Functions or variables defined in a module are not visible outside unless you explicitly export them.
  • You can place the export keyword in front of any variable, function, or class declaration to export it from the module.
  • You can use the import keyword to consume the exported variable, function, or class declaration.
  • Modules are singletons. Only a single instance of a module exists, even if it was imported multiple times.

Some exporting possibilities are listed here:

// export data
export let color: string = "red";

// export function
export function sum(num1: number, num2: number) {
return num1 + num1;
}

// export class
export class Rectangle {
constructor(private length: number, private width: number) { }
}

You can declare a variable, function, or class and export it later. You can also use the as keyword to rename exports. A new name is the name used for importing:

class Rectangle {
constructor(private height: number, private width: number) { }
}

export {Rectangle as rect};

Once you have a module with exports, you can access its functionality in another module using the import keyword:

import {sum} from "./lib.js";
import {Rect, Circle} from "./lib.js";

let sum = sum(1, 2);
let rect = new Rect(10, 20);

There is a special case that allows you to import the entire module as a single object. All exported variables, functions, and classes are available on that object as properties:

import * as lib from "./lib.js";

let sum = lib.sum(1, 2);

Imports can be renamed with the as keyword and used under the new name:

import {sum as add} from "./lib.js";

let sum = add(1, 2);
主站蜘蛛池模板: 涞水县| 浙江省| 华蓥市| 水城县| 和田市| 榆社县| 四平市| 常州市| 四平市| 衢州市| 隆化县| 紫云| 正镶白旗| 儋州市| 兴安县| 越西县| 皋兰县| 喜德县| 修水县| 伊春市| 留坝县| 社旗县| 长岛县| 鄂托克旗| 霍邱县| 那曲县| 新余市| 葵青区| 比如县| 玉环县| 临夏县| 方城县| 西乌| 崇仁县| 丰都县| 阜城县| 厦门市| 剑阁县| 紫云| 区。| 虹口区|