javascript - JavaScript 算术和 DOM 中的 NaN 值出现问题

标签 javascript html

我遇到的问题是我的函数calculate()。该程序的目的是使用 JavaScript 和 html 创建动态电子表格,并使用 CSS 进行装饰。

到目前为止,我已将值插入到电子表格中,但是当尝试对其运行简单的加法计算时,我从单元格中获取的值未正确获取。

这是给我带来问题的具体功能。我对草率的代码表示歉意。任何帮助将不胜感激,我确信这是我所缺少的简单内容。

编辑::纠正了这个问题,对于那些想知道的人,我不得不调用 not innerHTML.text 或 value。它必须只是相关单元格上的 .innerHTML。

function calculate() {
    //create two variables to get the values in the row and columns
    var row1, row2, col1, col2, total, totalInsert;

    var row = document.getElementById("row");
    var col = document.getElementById("col");
    var value = document.getElementById(row + "_" + col);
    var formula = document.getElementById("inputText");

    formula = formula.value; //=SUM(1,2,2,1)
    formula1 = formula;

    //get the raw values to ints
    row = row.value;
    col = col.value;

    //get JUST the formula in questions part    
    formula = formula.substr(0,4);

    //Parsing the the selected cells from =sum(1,1,2,1) into  Cell ID's
    col1 = parseInt(formula1.substr(5, 1));//row 1
    row1 = parseInt(formula1.substr(7, 1));
    col2 = parseInt(formula1.substr(9, 1));
    row2 = parseInt(formula1.substr(11, 1)); // column2

    //this gives us the proper cell's address. id=1_1 
    var td1 = col1 + "_" + row1;
    var td2 = col2 + "_" + row2;

    //problem starts around here
    var sum = document.getElementById(td1);
    var sum2 = document.getElementById(td2);

    //this returns a undefined value
    sum = sum.value;
    sum2 = sum2.value;

    //this restults in a NaN
    sum = parseInt(sum);
    sum2 = parseInt(sum2);

    //creating the total value
    total = sum + sum2;

    //returning values
    totalInsert = document.getElementById(td1).innerHTML = total;
}

最佳答案

这部分对我来说似乎很奇怪,您选择两个元素,然后将它们组合为一个字符串来查找另一个元素?

var row = document.getElementById("row");
var col = document.getElementById("col");
var value = document.getElementById(row + "_" + col);

我不确定这是否会达到您的预期...根据我的经验,您会得到这样的结果:

document.getElementById('[object Object]_[object Object]');

或者:

document.getElementById('[object HTMLDivElement]_[object HTMLDivElement]');

...取决于浏览器。现在显然你可以有一个具有这种id的元素,但这有点疯狂;)

在我看来,rowcol元素是输入,所以也许你实际上的意思是:

var row = document.getElementById("row");
var col = document.getElementById("col");
var value = document.getElementById(row.value + "_" + col.value);

关于javascript - JavaScript 算术和 DOM 中的 NaN 值出现问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13032862/

相关文章:

javascript - 无法在页面中找到元素。检查元素显示与源页面不同的 HTML Python - Selenium

html - 文本对齐和绝对定位

javascript - 谷歌图表 html 工具提示问题

javascript - 类型错误 : children is not a function

javascript - iFrame 在 Chrome 中无法正确加载

html - 取消隐藏仅在悬停状态下显示的 Div

c# - 使用 flexbox 的 3 列流体布局第 3 列向左推

javascript - 在 vue.js 中保留 DOM 更新时的滚动位置

javascript - 了解Backbone设置方法和模型

javascript - 将 List<int> 作为 Javascript 函数的参数传递