TS泛型、模块、命名空间

前景概要

在上一篇声明文章里,变量、参数、函数返回值的类型都是在已知的前提下声明的,在真是情景中,也会有我们定义的时候未知其类型的变量或参数,在考虑复用性的情况下泛型给我们提供了强大而灵活的功能,可以支持多种类型的数据。

例子

我们想写一个函数,它拥有一个参数我们不知道它的类型但是我们希望函数的返回值的类型跟参数的类型一样。

  • 方案1: 定义参数跟返回值的类型为 any,但是一旦我们这么做我们就是向类型检查做妥协,放弃了类型检查,并且不一定能够返回与参数同类型的值。
  • 方案2: \color{#34a853}{使用泛型}
方案1: any
function getValue(value: any):any {
  ... // 过程如果操作不当 valueTypeRes 的类型不是参数value的类型也会编译通过,返回值类型的正确性存在无法确认的风险。
  return valueTypeRes;
}
方案2: 泛型
/**
 * T 代表泛型,用其他大写字母也可以,建议用T,它的类型是调用方法的时候决定的
 * 在使用泛型的方法里也可以用泛型定义变量的类型
 */
function getValue<T>(value:T):T {
  return value;
}
// 调用的方式
getValue<string>('1'); 
// 调用的时候决定参数的类型为string,返回值也必须为string

泛型类

// 法语:class className:<T>{}
class exampleClass<T> {
  public value:T; 
  exampleFunc(value:T):T {
    return value;
  }
}

泛型接口

泛型函数类型接口的语法跟函数类型接口一样,忘记了可以在声明文章里面查阅(传送门:TS属性、方法、类、接口声明大杂烩

写法1
interface IExample {
  <T>(value:T):T;
}

let getValue:IExample = <T>(value:T):T => value;

写法2
interface IExample<T> {
  (value:T):T;
}

let getValue:IExample<number> = (value:number):number => value;

写法3
interface IExample<T> {
  (value:T):T;
}
function getValue<T>(value:T):T {
  return value;
}

let getNumberValue:IExample<number> = getValue;

模块

模块拥有其自身的作用域,定义在模块里的变量,方法,类等在模块外部是不可见的。不过我们可以使用 export 的方式导出它们。相反我们需要用到模块导出的变量、方法、类等的时候使用 import 引入它们,语法是es6的语法。
模块用例:平时的公共常量和公共的方法的抽离,就是抽离成一个模块。在使用的时候 import 它们。


公共模块

命名空间

命名空间的概念跟模块的概念差不多,相当于是模块中的模块,它的存在有效避免多人同时开发时的命名冲突。

// 命名空间
/**
 * 语法:namespace 空间名字 {}
 * 在命名空间外部调取命名空间的变量、方法等:空间名字.变量 || 方法等
 */
namespace spaceA {
  interface IExmple {
    valueA: string;
    funcA(): string;
  }
  export class classA implements IExmple {
    valueA: string;
    constructor(value: string) {
      this.valueA = value;
    }
    funcA() {
      return 'success';
    }
  };
}
// 在外部调用命名空间属性
let objA = new spaceA.classA('value');
// 在命名空间里调用其他命名空间的属性
namespace spaceB {
  let objB = new spaceA.classA('value');
// 接口命名和 spaceB 里一样不会冲突
  interface IExmple {
    valueA: string;
    funcA(): string;
  };
}

推荐:如果想要使得代码更简洁,也可以把每个命名空间单独抽离成一个模块~

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,332评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,508评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,812评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,607评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,728评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,919评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,071评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,802评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,256评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,576评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,712评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,389评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,032评论 3 316
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,798评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,026评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,473评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,606评论 2 350