繁体   English   中英

打字稿功能怎么做?

[英]How to do typescript function chaining?

我想在打字稿中使用函数链。

考虑一堂课

export class numbOp(){
  private n;
  constructor(int num){
    this.n = num;
  }

  public add(inc = 1){
    this.n = this.n + inc;
  }

}

我如何使用它(1)

let finalNumber = new numbOp(3);
console.log(finalNumber) // Output: 3

我如何使用它作为(2)

let finalNumber = new numbOp(3).add();
console.log(finalNumber) // Output: 4

我如何使用它作为(3)

let finalNumber = new numbOp(3).add().add();
console.log(finalNumber) // Output: 5

我如何使用它(4)

let finalNumber = new numbOp(3).add().add(2).toString();
console.log(finalNumber) // Output: "6"

请帮助我实现这一目标。 提前致谢 :)

您只需要从要链接的函数中返回this

class numbOp {
    private n: number;
    constructor(num: number) {
        this.n = num;
    }

    public add(inc = 1) : this { // annotation not necessary added to address comments
        this.n = this.n + inc;
        return this;
    }
    toString() { 
        return this.n;
    }

}
let finalNumber = new numbOp(3);
console.log(finalNumber + "") // Output: 3
//How do I use it as (2)
let finalNumber2 = new numbOp(3).add();
console.log(finalNumber2 + "") // Output: 4
//How do I use it as (3)
let finalNumber3 = new numbOp(3).add().add();
console.log(finalNumber3 + "") // Output: 5
//How do I use it as (4)
let finalNumber4 = new numbOp(3).add().add(2).toString();
console.log(finalNumber4) // Output: "6"

编辑

由于console.log部分似乎比评论中的链部分更有趣,我将添加方法以确保控制台中的输出是一个数字:

  1. 覆盖toString并使用字符串强制来获取对象的字符串表示形式
  2. 需要在显示之前调用终结器方法(即,在完成链时不要忘记调用toString
  3. 覆盖valueOf并使用一元+运算符(这也将使您的类在二进制运算中可用

最后一个选项的代码:

class numbOp {
    private n: number;
    constructor(num: number) {
        this.n = num;
    }

    public add(inc = 1) : this { // annotation not necessary added to address comments
        this.n = this.n + inc;
        return this;
    }
    valueOf() { 
        return this.n;
    }

}
let finalNumber2 = new numbOp(3).add();
console.log(+finalNumber2) // Output: 4
console.log(1 + (+finalNumber2)) // Output: 5
console.log(1+(finalNumber2 as any as number)) // Output: 5

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM