1

我正在编写一个非常基本的 html 计算器。最终结果和用户输入显示在下面的“textDisplay_”区域中:

<div id ="textDisplayRow_"> 
   <div id = "textDisplay_" class = "calcTextDisplay">0.0</div>
</div>

我还有一个 JavaScript 代码,它使用以下函数获取显示的值并将其解析为浮点数:

function getCurrentText() {
    "use strict";
    return document.getElementById("textDisplay_").innerHTML;
}

function getDisplayedNum() {
    "use strict";
    if (getCurrentText() === emptyMesg) {
        return maxSafeInt;
    }

    var t = 1*getCurrentText();
    //var t = parseFloat(getCurrentText(), 10); 

    if ((isNaN(t)) || (t === undefined)) {
        return 0;
    } else {
        return t;
    }
}

这段代码在桌面浏览器上运行良好(我已经在 Chrome、FireFox 和 IE 上对其进行了测试)它们看起来都不错,如果我输入:3.14*2 并按'=',它们会给我 6.28。

但是在我的 android 4 上,使用最新版本的移动版 chrome 和 firefox,所有的十进制数字都被四舍五入了!所以如果我输入“3.14*2=”,我会得到“6”!

我该如何解决这个问题?我查看了其他包含 parseFloat 的帖子不起作用,但没有一个与这个问题相似。两者都给出相似的结果:

1*getCurrentText();

parseFloat(getCurrentText(), 10); 

一种选择是编写我自己的 parseFloat(我以前为微控制器做过这个!)但我真的不想那样做。

提前非常感谢。

4

2 回答 2

1

我很确定你的问题不是你想的那样。请在您的桌面和移动浏览器上访问此页面。对我来说,它们产生相同的结果。

https://jsfiddle.net/xpkhqdLa/1/

作为str一个包含浮点数的字符串,以下所有内容都会产生相同的、正确的浮点值:

var values = [ str*1, 1*str, 1.0*str, parseFloat(str) ];
于 2016-04-06T17:26:28.310 回答
0

你可以试试:

var t = 1.0 * getCurrentText();

得到一个浮动。

于 2016-04-05T23:23:03.950 回答