迭代输入元素以将值赋给数组

时间:2010-02-23 07:51:21

标签: javascript jquery

以下代码提取已选择上传的文件列表。

它基本上将输入元素附加到表单元素上方的div中:

<div id = "files_list"> </div>

如何在单击提交按钮时将所有属性名称存储在数组中 - fileNamesArray。

我的尝试我还没检查是否有效:

//尝试开始

//我的方法: //如果没有选择上传文件并单击提交,则提醒用户

//我必须遍历输入元素并包含在div id =“files_list”中,获取所有文件名并将所有值推送到数组 $ filesArray 。 / p>

//粗略尝试

$("Submit").click(function () {

    $filesArray

    $(div#files_list).getElementById('input').each(function($filesArray) {  
        filesArray.push($this.attr("value"))
    });

    while( $filesArray.size != 0) {
        document.writeln("<p>" + $filesArray.pop() + "</p>");
    }
}

//尝试结束:我打印出名称只是为了验证

以下代码:

$(document).ready(function(){   
var fileMax = 6;
$('#asdf').after('<div id="files_list" style="border:1px solid #666;padding:5px;background:#fff;" class="normal-gray">Files (maximum '+fileMax+'):</div>');
$("input.upload").change(function(){
doIt(this, fileMax);
});
});

function doIt(obj, fm) {
if($('input.upload').size() > fm) {alert('Max files is '+fm); obj.value='';return true;}
$(obj).hide();
$(obj).parent().prepend('<input type="file" class="upload" name="fileX[]" />').find("input").change(function() {doIt(this, fm)});
var v = obj.value;
if(v != '') {
$("div#files_list").append('<div>'+v+'<input type="button" class="remove" value="Delete" style="margin:5px;" class="text-field"/></div>')
.find("input").click(function(){
$(this).parent().remove();
$(obj).remove();


return true;
});
}
};

HTML表单的代码:

<td><form action="test.php" method="post" enctype="multipart/form-data" name="asdf" id="asdf">
      <div id="mUpload">
    <table border="0" cellspacing="0" cellpadding="8">
      <tr>
        <td><input type="file" id="element_input" class="upload" name="fileX[]" /></td>
        </tr>
      <tr>
        <td><label>
          <textarea name="textarea" cols="65" rows="4" class="text-field" id="textarea">Add a description</textarea>
        </label></td>
        </tr>
      <tr>
        <td><input name="Submit" type="button" class="text-field" id="send" value="Submit" /></td>
        </tr>
      </table><br />
        </div>
</form>

    <p class="normal"></td>

1 个答案:

答案 0 :(得分:1)

var my_array = new Array();

$('#asdf').bind('submit', function() {
    $.each(this.elements, function() {
        if ( this.type == 'file' ) {
            $('#file_list').append($(this).clone());
            my_array.push(this.value);
        }
    });

    for ( var i=0; i < my_array.length; i++ )
        alert(my_array[i]);
});

你走了!

编辑由于OP的评论而更新。