xgqfrms™, xgqfrms® : xgqfrms's offical website of cnblogs! xgqfrms™, xgqfrms® : xgqfrms's offical website of GitHub!

TypeScript Generics All In One

TypeScript Generics All In One

"use strict";

/**
 *
 * @author xgqfrms
 * @license MIT
 * @copyright xgqfrms
 * @created 2022-02-07
 * @modified
 *
 * @description generic
 * @augments
 * @example
 * @link
 *
 */

const log = console.log;

class Person<T> {
  run(value: T) {
    log('run', value);
  }
  static getName(value: T) {
    // Static members cannot reference class type parameters.ts(2302)
  }
}

const p = new Person<number>();
p.run(1);
p.run('1');
// Argument of type 'string' is not assignable to parameter of type 'number'.ts(2345)


// 泛型约束
interface Length {
  length: number,
}

class Test<T extends Length> {
  run(value: T) {
    log('run', value);
  }
  getLength(len: T) {
    log('length =', len, len.length);
  }
}

const t = new Test<string>();
t.run('abc');
t.getLength('abc');
t.getLength(123);
// Argument of type 'number' is not assignable to parameter of type 'string'.ts(2345)

interface Len<T> {
  length: T,
}

class Bug<T extends Len<T>> {
  run(value: T) {
    log('run', value);
  }
  getLength(len: T) {
    log('length =', len, len.length);
  }
}

// const t = new Bug<string>();
// Type 'string' does not satisfy the constraint 'Len<string>'.ts(2344)
// const t = new Bug<string[]>();
/*
Type 'string[]' does not satisfy the constraint 'Len<string[]>'.
  Types of property 'length' are incompatible.
    Type 'number' is not assignable to type 'string[]'.ts(2344)
 */

export {};


Promise



feat

https://github.com/microsoft/TypeScript-Website/issues/2256


(() => {
  const tryLinks = document.querySelectorAll(`[class="playground-link"]`);
  for (let item of tryLinks) {
    item.target = "_blank";
  }
})();

refs

https://www.typescriptlang.org/docs/handbook/generics.html

https://www.typescriptlang.org/docs/handbook/2/generics.html

https://www.typescriptlang.org/play



©xgqfrms 2012-2025

www.cnblogs.com/xgqfrms 发布文章使用:只允许注册用户才可以访问!

原创文章,版权所有©️xgqfrms, 禁止转载 🈲️,侵权必究⚠️!


posted @   xgqfrms  阅读(42)  评论(3编辑  收藏  举报
相关博文:
阅读排行:
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· .NET10 - 预览版1新功能体验(一)
历史上的今天:
2021-02-07 Steam 钓鱼模拟器 All In One
2021-02-07 JavaScript Engine 可视化
2021-02-07 js Promise finally All In One
2021-02-07 AirPods Max 出厂激活是怎么回事
2021-02-07 js function All In One
2021-02-07 element-ui dialog loading
2020-02-07 vue & $router & History API
点击右上角即可分享
微信分享提示