/*
其实前面一些都是废话,因为都和C#类似.从模块开始就需要深入的去理解了
文档反复声明了 内部模块现在称做 命令空间 外部模块称为 模块
模块在其自身的作用域里执行,而不是在全局作用域里,也就是说模块内的变量函数类等在模
块外部是不可见的.
模块是自声明的,两个模块之间的关系是通过文件级别上使用 imports exports建立
模块使用模块加载器去导入其它的模块,像CommonJS、Require.JS 作用是执行此模块代码前
去查找并执行这个模块的做有依赖
*/ /*
说了这么多,什么才是一个模块? 上面的话比较官方,通常我们的模块是一个ts文件,但是也
不是说一个文件就是一个真正意义上的模块,前提是文件中包含任何顶级的import或者export
才是一个模块
*/ /*
从最基础的导出开始
在一个模块中,我们要将需要被访问访问的 类、函数等使用 export关键字导出
*/
interface interfaceExport { };
class classExport { };
//进行导出 如果对名称不满意可以使用 as 语法重命名 比如 classExport as newName export { interfaceExport, classExport as newClassName}; /*
当我们需要在另一个模块中只导出其它模块的部分内容, 可以使用重新导出
语法 exprot from '模块名称' 直译就是导出一个东西,但是它不是我的,它from自xx模块
export { interfaceExport : newinterfaceExport } from "./模块";
export * from "模块名称" * 代表所有内容
* 默认导出,模块可以有一个且只能有一个默认导出.default 的好处在哪里?
对默认的导出在导入时可以忽略其名称 语法
export default
*/ /*
导入也是非常简单的,使用 import 可以轻松进行导入,格式 import {名称} from '模块'
* 如果模块内导出的太多, 一个一个的进行improt是非常麻烦的可以使用
import * as NewName from '模块'
意思是导入'模块'中所有被导出的,NewName做为它们的根
*/ /*
需要嗨皮的是,导入是懒加载的.也就是只有在使用的时候才去真正的加载,对于一些导入了
但是并没有进行使用的是不会去加载的,这无疑提高了性能
*/ //简单提一下,文件可以定义成.D.TS文件,导出的时候可以自定义名称 declare model "Name"{ export ....}
/*
相信对于命名空间NameSpaced大家都很熟悉,可以很方便的管理我们的类.现在TypeScript中
也有了命名空间
一般来说命名空间是无需使用的,因为我们有模块的概念,一个文件就是一个模块,一般来说这
是够用的
但是随着功能越来越多放到一个文档是不合适的,我们需要拆分成不同的文件.这时候使用命
名空间管理是最佳选择
*/
--- 命名空间.ts
namespace testNameSpace {
export function fun1() { };
}
上面是命名空间.ts下的内容,里面有一个命名空间 testNameSpace ---命名空间2.ts
namespace testNameSpace {
export function fun2() { };
}
然后在命名空间2.ts下继续在testNameSpace命名空间下添加方法 ---test.ts
//使用testNameSpace空间下的fun1方法
testNameSpace.fun1();
实际上命名空间是一个普通的JavaScript对象,并且可以在多个文件使用,不需要导入。这听起来就是全局的,所以命名空间是不被推荐使用的,模块才是真爱

TypeScript 素描 - 模块的更多相关文章

  1. TypeScript 素描 - 模块解析、声明合并

    模块解析 模块解析有两种方式 相对方式  也就是以/或 ./或-/开头的,比如import jq  from "/jq" 非相对方式  比如 import model  from ...

  2. TypeScript 素描 - 模块、命名空间

    /* 其实前面一些都是废话,因为都和C#类似.从模块开始就需要深入的去理解了 文档反复声明了 内部模块现在称做 命令空间 外部模块称为 模块 模块在其自身的作用域里执行,而不是在全局作用域里,也就是说 ...

  3. TypeScript 素描-基础类型

    博文读自 TypeScript 官方文档而来,不具有学习性,仅是本人学习时记录以供日后翻阅 ,有学习TypeScript的朋友还请去看更为详细的官方文档 TypeScript官网文档中的基础类型, T ...

  4. TypeScript Modules(模块)

    本文概述了TypeScript中如何使用模块以各种方式来组织代码.我们将涵括内部和外部的模块,并且讨论他们在适合在何时使用和怎么使用.我们也会学习一些如何使用外部模块的高级技巧,并且解决一些当我们使用 ...

  5. TypeScript 之 模块

    https://m.runoob.com/manual/gitbook/TypeScript/_book/doc/handbook/Modules.html 外部模块简写 外部模块简写:declare ...

  6. typescript - 7.模块

    我们可以把一些公共的功能单独抽离成一个文件作为一个模块. 模块里面的变量 函数 类等默认是私有的,如果我们要在外部访问模块里面的数据(变量.函数.类), 我们需要通过export暴露模块里面的数据(变 ...

  7. TypeScript入门九:TypeScript的模块

    关于TypeScript模块的基本使用方法 Ts的模块化语法与ES6的语法基本是一致(关于一些细节特性没有测试,请各自自行测试),然后再由tsconfig.json的module字段来描述转码类型,具 ...

  8. TypeScript 素描 - 类

    本文虽然是学自官方教程而来,但是也融入了自己的理解,而且对官方的例子做了一些修改 /* 类 面向对象编程的一大核心 使用C#.Java进行编程的朋友肯定已经是不能够再熟悉了 TypeScript的类与 ...

  9. TypeScript 素描 - 接口

    /* 接口 C#写多了,接口也自然也是理解的.不过TypeScript中的接口与 C#中的还是有些区别的 接口的作用就是为这些类型命名和为你的代码或第三方代码定义契约 */ //为方法的参数做契约 i ...

随机推荐

  1. UVa 1625 Color Length

    思路还算明白,不过要落实到代码上还真敲不出来. 题意: 有两个由大写字母组成的颜色序列,将它们合并成一个序列:每次可以把其中一个序列开头的颜色放到新序列的尾部. 对于每种颜色,其跨度定义为合并后的序列 ...

  2. BZOJ3856: Monster

    题目:http://www.lydsy.com/JudgeOnline/problem.php?id=3856 题解:怎么乱搞一下都可以把 代码: #include<cstdio> #in ...

  3. asp.net创建XML文件方法

    方法一:按照XML的结构一步一步的构建XML文档.    通过.Net FrameWork SDK中的命名空间"System.Xml"中封装的各种类来实现的 方法一:按照XML的结 ...

  4. Leap Motion 开发笔记

    Leap Motion 体系架构 Leap Motion支持所有主流操作系统,leap motion在Windows系统下是作为一个服务运行的,在Mac和Linux是后台守护进程.软件通过USB线连接 ...

  5. datatables使用总结篇

    <!doctype html> <html> <head> <meta charset="gbk"/> <meta name= ...

  6. 2014-LAMP兄弟连视频下载地址汇总

    linux 兄弟连2014年新版Linux视频教程百度网盘下载 http://pan.baidu.com/s/1kTsjVfx http://pan.baidu.com/s/1sjJf2OX 兄弟连2 ...

  7. poj 2184 Cow Exhibition

    // 给定n头牛,每头有属性智商和幽默感,这两个属性值有正有负,现在要从这n头牛中选出若干头使得他们的智商和与幽默感和不为负数,// 并且两者两家和最大,如果无解输出0,n<=100,-1000 ...

  8. Dev gridControl 按回车增加一行

    将NewItemRowPosition属性设置为Top或Bottom, 在这样的新行中输入数据后,会自动添加到绑定的数据源中的, 如果你希望在按回车时焦点跳至下一列, 只需要设置GridView的Op ...

  9. Team them up!

    题意: 给出n个人以及认识其他人的情况,现在要把所有人分成两队,每队至少一人,求使两队人数差距最小且每队内部的人都相互认识的分队情况. 分析: 这道题让我学习到了不少,首先看到使差距最小就想到了背包, ...

  10. 用javascript 面向对象制作坦克大战(四)

    我们现在还差一个重要的功能,没错,敌人坦克的创建以及子弹击中敌人坦克时的碰撞检测功能. 5.  创建敌人坦克完成炮弹碰撞检测 5.1   创建敌人坦克对象 敌人坦克和玩家坦克一样,同样继承自我们的坦克 ...