Typescript:尝试添加两个变量,但得到两个变量的串联

2024-01-29

我的 Typescript 类中有三个变量:

A:number;
B:number;
C:number;

在课程的另一部分中,我尝试添加两个变量 A 和 B :

this.C = this.A+this.B; // A =20 and B = 50;

我在 html 模板中显示 C

<span>{{C}}</span>

我的问题是,而不是添加两个变量(20+50=70)我得到了串联(2050)!!

有人能帮助我吗 ?

UPDATE :

这是导致问题的确切代码部分:

goTo(page:number,type:script) {
    //    
    this.pageFirstLineNumber = page;
    this.pageLastLineNumber = page + this.LINE_OFFSET; //concatenation!!
}

请注意,pageLastNumber 被声明为数字类型,LINE_OFFSET 也是数字类型,我找到了此问题的解决方案,但打字稿编译器输出错误(禁止 eval):

////
....
this.pageFirstLineNumber = eval(page.toString()); // now It works !!
this.pageLastLineNumber = page + this.LINE_OFFSET; //concatenation!!

UPDATE

这是 LINE_OFFSET 变量的声明:

private _calculateOffset(fontSize: number) {
    let linesDiff = (fontSize * 27) / 14;
    let lines:number = 27 - (linesDiff - 27);
    this.LINE_OFFSET = Math.floor(lines);
    if (fontSize >= 17 && fontSize <= 20) {
        this.LINE_OFFSET += (Math.floor(fontSize / 3) - 2);
    }
    if (fontSize > 20 && fontSize <= 23) {
        this.LINE_OFFSET += (Math.floor(fontSize / 2) - 2);
    }
    if (fontSize > 23 && fontSize <= 25) {
        this.LINE_OFFSET += (Math.floor(fontSize / 2));}
    if (fontSize > 25 && fontSize <= 27) {
        this.LINE_OFFSET += (Math.floor(fontSize / 2) + 1);
    }
    if (fontSize > 27 && fontSize <= 30) {
        this.LINE_OFFSET += (Math.floor(fontSize / 2) + 4);
    }
}

在数字前面加上+:

let a = +b + +c;

ref https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Operators/Arithmetic_Operators#Unary_plus_()

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

Typescript:尝试添加两个变量,但得到两个变量的串联 的相关文章

随机推荐