计算数组中的数据

时间:2011-07-21 07:01:54

标签: javascript jquery arrays arraylist

我有关于数组的这个(简单)问题。我试图获得在html中输入的所有板脚的总数。这是一个正在运行的示例代码:click here

(感谢AsKaiser提供的代码)。

现在,我想要做的是每当我点击go按钮时,它会自动计算在该阵列中输入的总板尺。因此,每当我输入该表单中的内容并单击go时,数据将转到该数组,所有板脚的总数将显示在下面的输入框中。当我向数组添加数据时,它会不断变化。

我无法让它工作,并且我的总数值总是NaN

3 个答案:

答案 0 :(得分:1)

您的代码非常混乱。 plank_data有什么意义?

为什么不这样做呢,它更有意义。

function Plank()
{
  var self = this;
  self.Number = 0;
  self.Thickness = 0;
  self.Width = 0;
  self.Length = 0;
  self.Quantity = 0;

  self.GetBoardFoot = function()
  {
    return (((parseFloat(self.Thickness) * parseFloat(self.Width) * parseFloat(self.Length) * parseFloat(self.Quantity)) / 12);
  }
}

var planks = [];
function AddPlank()
{
  var myPlank = new Plank();
  myPlank.Number = $('#plank_number').val();
  myPlank.Thickness = $('#thickness').val();
  myPlank.Width = $('#width').val();
  myPlank.Length = $('#length_t').val();
  myPlank.Quantity = $('#quantity').val();
  planks.push(myPlank);
}

function GetTotalBoardPlank()
{
  var total = 0;
  for (var i = 0; i < planks.length; i++)
    total += planks[i].GetBoardFoot();
  return total;
}

function Go()
{
  AddPlank();
  $('#board_foot').val(parseFloat(GetTotalBoardPlank()));
}

答案 1 :(得分:0)

Is this what you are looking for?

plank_data = [];
$('#go').click(function() {

    var plankNum = parseFloat($('#plank_number').val() || 0.00),
        thick = parseFloat($('#thickness').val() || 0.00),
        width = parseFloat($('#width').val() || 0.00),
        length_t = parseFloat($('#length_t').val() || 0.00),
        quantity = parseFloat($('#quantity').val() || 0.00);

    //compute board foot
    board_foot = parseFloat((thick * width * length_t * quantity) / 12);

    // show board foot
    $('#board_foot').val(board_foot);

    var current_data = {};

    $('#plank_form input:text:not("#board_foot")').each(function() {
        var $this = $(this);
        current_data[$this.attr('id')] = parseFloat($this.val() || 0.00);
        $this.val('');
    });

    //this will push data/add data to array
    plank_data.push(current_data);

    var total = parseFloat(plankNum + thick + width + length_t + quantity);
    $('#total').val(total);
});

答案 2 :(得分:-2)