Javascript 向Typescript中的基类添加扩展
我在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
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...
};