zoukankan      html  css  js  c++  java
  • ts 模块

    简介

    TypeScript 模块的设计理念是可以更换的组织代码。

    模块是在其自身的作用域里执行,并不是在全局作用域,这意味着定义在模块里面的变量、函数和类等在模块外部是不可见的,除非明确地使用 export 导出它们。类似地,我们必须通过 import 导入其他模块导出的变量、函数、类等。

    两个模块之间的关系是通过在文件级别上使用 importexport 建立的。

    模块使用模块加载器去导入其它的模块。 在运行时,模块加载器的作用是在执行此模块代码前去查找并执行这个模块的所有依赖。 大家最熟知的JavaScript模块加载器是服务于 Node.js 的 CommonJS 和服务于 Web 应用的 Require.js

    此外还有有 SystemJsWebpack

    模块导入导出语法

    模块导出使用关键字 export 关键字,语法格式如下:

    // 文件名 : SomeInterface.ts 
    export interface SomeInterface { 
       // 代码部分
    }
    

    要在另外一个文件使用该模块就需要使用 import 关键字来导入:

    import someInterfaceRef = require("./SomeInterface");
    

    示例

    IShape.ts 文件代码

    /// <reference path = "IShape.ts" /> 
    export interface IShape { 
       draw(); 
    }
    

    Circle.ts 文件代码

    import shape = require("./IShape"); 
    export class Circle implements shape.IShape { 
       public draw() { 
          console.log("Cirlce is drawn (external module)"); 
       } 
    }
    

    Triangle.ts 文件代码

    import shape = require("./IShape"); 
    export class Triangle implements shape.IShape { 
       public draw() { 
          console.log("Triangle is drawn (external module)"); 
       } 
    }
    

    TestShape.ts 文件代码

    import shape = require("./IShape"); 
    import circle = require("./Circle"); 
    import triangle = require("./Triangle");  
     
    function drawAllShapes(shapeToDraw: shape.IShape) {
       shapeToDraw.draw(); 
    } 
     
    drawAllShapes(new circle.Circle()); 
    drawAllShapes(new triangle.Triangle());
    

    使用 tsc 命令编译以上代码(AMD):

    tsc --module amd TestShape.ts 
    

    或者编译成commonjs

    tsc --module commonjs TestShape.ts
    

    具体编译结果,可去原文看

    转载自:https://www.runoob.com/typescript/ts-module.html

  • 相关阅读:
    PS后期合成,你和大神的差距就这5步!
    欧几里得算法:从证明等式gcd(m, n) = gcd(n, m mod n)对每一对正整数m, n都成立说开去
    谜题:过桥问题
    《世界是数字的》读书笔记第一部分_硬件篇
    完全偶图K(3,3)与完全图K5是否存在平面表示
    Dijkstar算法的数学原理
    LeetCode 141. Linked List Cycle
    LeetCode 155. Min Stack
    LeetCode 160. Intersection of Two Linked Lists
    LeetCode 165.Compare Version Numbers
  • 原文地址:https://www.cnblogs.com/makalochen/p/14515968.html
Copyright © 2011-2022 走看看