Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/javascript/466.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Javascript 向Typescript中的基类添加扩展_Javascript_Typescript - Fatal编程技术网

Javascript 向Typescript中的基类添加扩展

Javascript 向Typescript中的基类添加扩展,javascript,typescript,Javascript,Typescript,我在javascript中添加了一个关于数字的方法。现在我想让这个方法在typescript中可用,但我不知道如何通过定义文件添加它 我的方法是 Number.prototype.formatMoney = function(c, d, t){ var n = this, c = isNaN(c = Math.abs(c)) ? 2 : c, d = d == undefined ? "." : d, t = t == undefined

我在javascript中添加了一个关于数字的方法。现在我想让这个方法在typescript中可用,但我不知道如何通过定义文件添加它

我的方法是

Number.prototype.formatMoney = function(c, d, t){
    var n = this,
        c = isNaN(c = Math.abs(c)) ? 2 : c,
        d = d == undefined ? "." : d,
        t = t == undefined ? "," : t,
        s = n < 0 ? "-" : "",
        i = parseInt(n = Math.abs(+n || 0).toFixed(c)) + "",
        j = (j = i.length) > 3 ? j % 3 : 0;
    return s + (j ? i.substr(0, j) + t : "") + i.substr(j).replace(/(\d{3})(?=\d)/g, "$1" + t) + (c ? d + Math.abs(n - i).toFixed(c).slice(2) : "");
};

除了在
Number
的原型上定义方法外,还需要在
Number
界面上定义方法:

interface Number {
    formatMoney(c, d, t): string;   
}
您可以在应用程序中的任何位置定义它,TypeScript将通过将其与现有的
Number
接口合并

顺便说一句,我强烈建议您为函数中的变量指定比
c
d
t
s
j
等更好的名称。。。由于变量没有描述性名称,开发人员需要更长的时间才能理解这些变量的含义,这会降低代码的可维护性

此外,我建议提供参数类型信息并使用:


另外,请注意,
i
未在函数中声明。

除了在
Number
的原型上定义方法外,还需要在
Number
界面上定义:

interface Number {
    formatMoney(c, d, t): string;   
}
您可以在应用程序中的任何位置定义它,TypeScript将通过将其与现有的
Number
接口合并

顺便说一句,我强烈建议您为函数中的变量指定比
c
d
t
s
j
等更好的名称。。。由于变量没有描述性名称,开发人员需要更长的时间才能理解这些变量的含义,这会降低代码的可维护性

此外,我建议提供参数类型信息并使用:

另外,请注意,
i
未在函数中声明

interface Number {
    formatMoney(value: number, decimalMark?: string, thousandsSeparator?: string): string;  
}

Number.prototype.formatMoney = function(value: number, decimalMark = ".", thousandsSeparator = ",") {
    // etc...
};