我有关于数组的这个(简单)问题。我试图获得在html中输入的所有板脚的总数。这是一个正在运行的示例代码:click here
(感谢AsKaiser提供的代码)。
现在,我想要做的是每当我点击go
按钮时,它会自动计算在该阵列中输入的总板尺。因此,每当我输入该表单中的内容并单击go时,数据将转到该数组,所有板脚的总数将显示在下面的输入框中。当我向数组添加数据时,它会不断变化。
我无法让它工作,并且我的总数值总是NaN
。
答案 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)