2

在我注释掉/或删除该alert()行之前,我有一个运行良好的 Javascript 函数。它计算最多 30 个字段的总和(如果它们存在并且它们是否具有值)。

HTML:

<input type="text" onblur="Calculatenettobrutto(1);">

JavaScript:

function Calculatenettobrutto(n) {
  var Feldnummer=n;
  var nettowert,bruttowert;
  var nettosumme, bruttosumme,neuenettosumme,neuebruttosumme;
  var Wertfuer='Mehrwertsteuersatz'
  //Mehrwertsteuer auslesen
  var dataString = 'Name='+Wertfuer;
  var thisObject = this;
  this.wert=$.ajax({
    type: "POST",
    url: "ajax_get_Einstellungen.php",
    data: dataString,
    cache: false,
    success: function(wert) {
      nettowert = document.getElementById('Netto'+Feldnummer).value;
      bruttowert = parseFloat(nettowert) * wert;
      document.getElementById('Brutto'+Feldnummer).value=parseFloat(bruttowert);
      return wert;
    }
  });

  var nettosumme=0,bruttosumme=0, x=1;
  while (x < 30) {
  var Feldname='Netto'+x;
  if ( document.getElementById('Netto'+x) ) {
    //If field Netto+x exist then check if it has a value
    var nettowert=document.getElementById('Netto'+x).value;
    //if it has a value add values to nettosumme and bruttosumme
    if (nettowert) {
      nettosumme=parseFloat(nettosumme)+parseFloat(document.getElementById('Netto'+x).value);
      //IF I COMMENT THIS OUT, I get a NAN in my Bruttosumme column
      alert(nettosumme);
      bruttosumme=parseFloat(bruttosumme)+parseFloat(document.getElementById('Brutto'+x).value);
    }
  }
  x++;
}
document.getElementById('Nettosumme').value=parseFloat(nettosumme);
document.getElementById('Bruttosumme').value=parseFloat(bruttosumme);

}

即使alert()线路被移除,我如何使它工作?

4

1 回答 1

6

问题是您执行了异步 ajax 请求:

<input type="text" onblur="Calculatenettobrutto(1)" />

Calculatenettobrutto一旦用户离开现场,这就会调用。然后调用你的函数:

var Feldnummer = 1;
this.wert=$.ajax({
   ...
   success: function(wert) {
      ...
      nettowert = document.getElementById('Netto'+Feldnummer).value;
      bruttowert = parseFloat(nettowert) * wert;
      document.getElementById('Brutto'+Feldnummer).value=parseFloat(bruttowert);
   }
});

//alert("Wait a little");
document.getElementById('Brutto'+Feldnummer).value <-- BANG

这里的问题如下: ajax() 中定义的函数在服务器返回ajax 调用结果时被调用, ajax() 之后的代码立即执行。因此,您尝试在设置之前从字段中获取值。

当警报窗口可见时,脚本暂停,ajax 调用返回并执行设置“Brutto...”值的“成功”代码。关闭警报后,代码将被执行,现在“Brutto...”有了一个值。

可能最简单的解决方案是将总和计算功能移至“成功”功能

于 2013-05-21T17:09:45.730 回答