如何动态添加HTML数组元素[]

时间:2012-04-04 13:59:39

标签: php javascript jquery html dom

我有一个表单,我需要动态添加用户想要的文本字段。我希望文本字段是一个数组,例如:

<input type="text" name="room_text[]">

我已经建立了一些我认为可行的东西。它成功添加了更多文本框。我动态地添加了两个带有javascript的文本框,使表单看起来像这样:

<input type="text" name="room_text[]">
      <input type="text" name="room_text[]">
      <input type="text" name="room_text[]">

但是,当我将它发布到PHP文件时,它只获得第一个值。我之所以知道这是一个javascript问题,是因为如果页面加载时有多个文本框,它可以正常工作。它只是当您使用javascript添加更多文本框时。

如果这有帮助,这是我用来添加框的jquery函数:

$('.add').live("click", function() {
    var mu = $(this).parent('td').parent('tr');
    var clone = $(this).parent('td').parent('tr').clone();
    $(clone).children('td').children('.add').remove();
    $(clone).children('td').children('.redtext').remove();
    $(clone).children('td').children('.remove').css("display", "inline");
    $(clone).css("display", "none");
    $(mu).after(clone);
    $(clone).show("fast");
});

1 个答案:

答案 0 :(得分:1)

我认为问题在于.clone()功能。你可以尝试一种不同的方法,比如说......

$('.add').live("click", function() {
    var mu = $(this).parent('td').parent('tr');
    var clone = '<tr>' + $(this).parent('td').parent('tr').html() + '</tr>';
    $(clone).children('td').children('.add').remove();
    $(clone).children('td').children('.redtext').remove();
    $(clone).children('td').children('.remove').css("display", "inline");
    $(clone).css("display", "none");
    $(mu).after(clone);
    $(clone).show("fast");
});

更新 - 糟糕。在那个版本中,“clone”是一个字符串,而不是一个元素,因此.children()函数不起作用......这是一个更正的版本:

$('.add').live("click", function() {
    var mu = $(this).parent('td').parent('tr');
    var clone = $('<tr>' + $(mu).html() + '</tr>');
    $(clone).children('td').children('.add').remove();
    $(clone).children('td').children('.redtext').remove();
    $(clone).children('td').children('.remove').css("display", "inline");
    $(clone).hide();
    $(mu).after(clone);
    $(clone).show("fast");
});​