一、泛型

1. 泛型函数

function getMin<T>(arr: T[]):T {
if(arr.length === 0) {
throw new Error("输入的数组没有元素");
}
let res: T = arr[0];
for (let i = 1; i < arr.length; i++) {
if(arr[i] < res) {
res = arr[i];
}
}
return res;
}

C++ 的泛型函数非常类似

2. 泛型类

下面这个类可以求出当前列表中最小的元素

class MinClass<T> {
private dataArr: T[] = [];
public add(...val: T[]): void {
this.dataArr.push(...val);
}
public getMin(): T {
if(this.dataArr.length === 0) {
throw new Error("当前数组没有元素");
}
let res: T = this.dataArr[0];
for (let i = 1; i < this.dataArr.length; i++) {
if(this.dataArr[i] < res) {
res = this.dataArr[i];
}
}
return res;
}
}

3. 泛型接口

写法一

interface ConfigFn {
<T>(value:T):T;
}
let getData:ConfigFn = function<T>(value:T):T {
return value;
}
getData<string>("张三");

写法二

interface ConfigFn<T> {
(value:T): T;
}
function getData<T>(value:T) {
return value;
}
var myGetData:ConfigFn<string> = getData;
myGetData("20");

两种写法的区别

  • 写法一:一般用于在使用时才规定泛型的类型,用法类似泛型函数
  • 写法二:一般用于约束函数参数传递的类型,类似 Java 中的:
public void func(List<Integer> array){
...
}

这样的参数约束。

二、模块化

TypeScript 中一个 ts 文件中的函数和变量都是该文件私有的,只有通过 export 输出才能被外部调用。

1. export写法一

例如以下情况,我们希望暴露两个函数供外部调用,可以这样写:

// db.ts
export function getData():any[] {
console.log("获取数据库的数据");
return [
{ title:"121312" },
{ title:"123123" }
]
} export function save() {
console.log("保存数据成功")
}

在需要使用的地方使用 import 关键字进行引入,语法如下:

import { aaa,bbb } from "模块的路径";

注意,引入时不需要加最后的 .ts 后缀名,示例如下:

// index.ts
import { getData,save } from "./05module";
let data:any[] = getData();
console.log(data);
save();

因为模块的输出默认是以对象形式进行的(即所有export的东西都被封装到一个对象中),所以如果我们希望直接使用其他模块的方法或字段,需要使用 {} 运算符取出来再使用。

2. export写法二

我们也可以将所有的东西统一输出,避免编写多个 export

function getData():any[] {
console.log("获取数据库的数据");
return [
{ title:"121312" },
{ title:"123123" }
]
} function save() {
console.log("保存数据成功")
} // 将所有需要输出的东西包装成对象
export {
getData,
save
}

3. 为引入的方法或变量起别名

当我们觉得引入的方法或变量的名字使用起来不太方便等时可以为它们起别名,使用 as 关键字:

import { save as saveData } from "./05module";
saveData();

4. export default的使用

一个模块中 export default 只能使用一次,一般当只希望暴露一个方法时可以使用,例如:

// db.ts
function getData():any[] {
console.log("获取数据库的数据");
return [
{ title:"121312" },
{ title:"123123" }
]
}
export default getData;

而此时的引入也不相同:

import getData from "./05module";
let data:any[] = getData();
console.log(data);

在引入的时候我们不需要使用 {} 操作符进行获取了,此外我们 import 后面的变量名也不需要和export的变量相同:

import hello from "./05module";
let data:any[] = hello();
console.log(data);

这样也是可以得到正确结果的

tips:使用 export 来导出一个类的操作和导出变量和方法的操作都是相同的,因为编译成 js 代码后,一个类本质上就是一个构造函数,在 js 中函数就是一种变量类型,因此操作都是一致的。

三、命名空间

语法:

namespace 命名空间名 {
...
}

作用:一个模块内可以有多个命名空间,不同命名空间中的相同标识符的变量、函数和类等等可以重名不发生冲突

导出命名空间:

export namespace A {
...
}

引入命名空间的方法和引入变量及函数的方式一致。

tips:命名空间中的内容默认都是私有的,即使导出了命名空间,但默认还是无法直接使用到命名空间内部的函数的,需要将它们也export出来。

示例:

export namespace A {
interface Animal {
name: string;
eat():void;
}
export class Dog implements Animal {
name: string;
constructor(name:string) {
this.name = name;
}
eat(): void {
console.log(`小狗${this.name}在吃狗粮`);
}
}
export class Cat implements Animal {
name: string;
constructor(name:string) {
this.name = name;
}
eat(): void {
console.log(`小猫${this.name}在吃鱼`);
}
}
} let dog = new A.Dog("小黑");
dog.eat();

TypeScript学习笔记(三)泛型、模块化和命名空间的更多相关文章

  1. Typescript 学习笔记三:函数

    中文网:https://www.tslang.cn/ 官网:http://www.typescriptlang.org/ 目录: Typescript 学习笔记一:介绍.安装.编译 Typescrip ...

  2. Typescript 学习笔记七:泛型

    中文网:https://www.tslang.cn/ 官网:http://www.typescriptlang.org/ 目录: Typescript 学习笔记一:介绍.安装.编译 Typescrip ...

  3. Typescript 学习笔记六:接口

    中文网:https://www.tslang.cn/ 官网:http://www.typescriptlang.org/ 目录: Typescript 学习笔记一:介绍.安装.编译 Typescrip ...

  4. Typescript 学习笔记五:类

    中文网:https://www.tslang.cn/ 官网:http://www.typescriptlang.org/ 目录: Typescript 学习笔记一:介绍.安装.编译 Typescrip ...

  5. Typescript 学习笔记四:回忆ES5 中的类

    中文网:https://www.tslang.cn/ 官网:http://www.typescriptlang.org/ 目录: Typescript 学习笔记一:介绍.安装.编译 Typescrip ...

  6. Typescript 学习笔记二:数据类型

    中文网:https://www.tslang.cn/ 官网:http://www.typescriptlang.org/ 目录: Typescript 学习笔记一:介绍.安装.编译 Typescrip ...

  7. Typescript 学习笔记一:介绍、安装、编译

    前言 整理了一下 Typescript 的学习笔记,方便后期遗忘某个知识点的时候,快速回忆. 为了避免凌乱,用 gitbook 结合 marketdown 整理的. github地址是:ts-gitb ...

  8. TypeScript学习笔记(八):1.5版本之后的模块和命名空间

    我之前有写过TS1.5版本之前的“模块”的笔记:TypeScript学习笔记(七):模块 但是TS这里的模块和在ECMAScript 2015里的模块(即JS原生支持了模块的概念)概率出现了混淆,所以 ...

  9. 学习笔记(三)--->《Java 8编程官方参考教程(第9版).pdf》:第十章到十二章学习笔记

    回到顶部 注:本文声明事项. 本博文整理者:刘军 本博文出自于: <Java8 编程官方参考教程>一书 声明:1:转载请标注出处.本文不得作为商业活动.若有违本之,则本人不负法律责任.违法 ...

  10. Oracle学习笔记三 SQL命令

    SQL简介 SQL 支持下列类别的命令: 1.数据定义语言(DDL) 2.数据操纵语言(DML) 3.事务控制语言(TCL) 4.数据控制语言(DCL)  

随机推荐

  1. 『心善渊』Selenium3.0基础 — 8、使用CSS选择器定位元素

    目录 1.CSS选择器介绍 2.CSS选择器定位语法 3.Selenium中使用CSS选择器定位元素 (1)通过属性定位元素 (2)通过标签定位元素 (3)通过层级关系定位元素 (4)通过索引定位元素 ...

  2. 2.14、制作Centos模板及优化操作

    1.安装系统: (1)规范网卡为eth0的模式: (2)选择时区: (3)选择支持的语言包含中文: (4)选择软件包: 补充:桌面版包选择: (5)关闭down机内存日志: (6)分区: 1)分区说明 ...

  3. 解决WebStorm开发vue提示Module is not installed、Unresolved variable or type

    WebStorme2021.1版本: Setting->Languages->JavaScript->Webpack由原先的disable选为Automatically即可(右下角弹 ...

  4. 使用Dice loss实现清晰的边界检测

    ​ 前言: 在深度学习和计算机视觉中,人们正在努力提取特征,为各种视觉任务输出有意义的表示.在一些任务中,我们只关注对象的几何形状,而不管颜色.纹理和照明等.这就是边界检测的作用所在. 关注公众号CV ...

  5. JAVA并发(8)-ThreadPoolExecutor的讲解

    很久前(2020-10-23),就有想法学习线程池并输出博客,但是写着写着感觉看不懂了,就不了了之了.现在重拾起,重新写一下(学习一下). 线程池的优点也是老生常谈的东西了 减少线程创建的开销(任务数 ...

  6. Could not connect to 'xxx.xx.xx.xxx' (port 22): Connection failed.

    刚刚使用xshell好好的,突然注销账号,准备重新连接突然连不上了. 这就很尴尬了,对我这种linux菜鸟只能去百度了,终于解决了,赶紧记录下这个坑 1.先登陆虚拟机,输入这段命令 查看ssh服务是否 ...

  7. ESP32的Flash加密知识

    一.Flash 加密功能用于加密与 ESP32-S2 搭载使用的 SPI Flash 中的内容.启用 Flash 加密功能后,物理读取 SPI Flash 便无法恢复大部分 Flash 内容.通过明文 ...

  8. 「AGC021E」Ball Eat Chameleons

    「AGC021E」Ball Eat Chameleons 考虑如何判定一个合法的颜色序列. 不妨设颜色序列中有 \(R\) 个红球,\(B\) 个蓝球,所以有 \(R+B=k\). 考虑分情况讨论: ...

  9. c语言函数的嵌套使用和矩阵运算

    这段时间,听刚刚学习c的同学说函数嵌套运用不太熟练,想做一个简单的程序进行练习,我也就当练练手了,哈哈.虽然说是比较简单,但是其中的思维也是值得思考的. 一.函数的嵌套使用 简单说明题目:对于等式 y ...

  10. web自动化测试(2):选择selenium优势?与PhantomJS/QTP/Monkey对比

    上篇 <web自动化测试(1):再谈UI发展史与UI.功能自动化测试>,自动化测试工具众多, PC端常用的功能自动化测试工具 Selenium:开源工具集,用于回归功能测试或者系统用例说明 ...