Добавление файловых входов динамически с помощью jquery? - PullRequest
4 голосов
/ 30 января 2011

Чтобы сделать мой weppage как можно более совместимым, я буду использовать обычный ввод файлов, проблема в том, что мне нужно предложить несколько загрузок.

Я думаю, что, когда первый вход установлен, второй будетпоказываться (максимум до 10).Скажем, что мы заполнили 5 и есть 6 видимых.Теперь мы очистим второй вход, это приведет к двум пустым входам, поэтому последний (6 (пустой)) ввод должен быть скрыт.

Возможно ли это с помощью Jquery?

Edit1Это то, что мне удается создать, это прекрасно работает.Однако я уверен, что кто-то, кто лучше знает jquery, мог бы сделать более умный скрипт:

В представлении:

        <div id="fileInput0" class="fileVisible">
            <input type="file" id="file0" name="files" />
            <input type="button" value="Töm" onclick="resetFileField(0)" />
        </div>
        <div id="fileInput1" class="fileHidden">
            <input type="file" id="file1" name="files" />
            <input type="button" value="Töm" onclick="resetFileField(1)" />
        </div>
        <div id="fileInput2" class="fileHidden">
            <input type="file" id="file2" name="files" />
            <input type="button" value="Töm" onclick="resetFileField(2)" />
        </div>
        <div id="fileInput3" class="fileHidden">
            <input type="file" id="file3" name="files" />
            <input type="button" value="Töm" onclick="resetFileField(3)" />
        </div>
        <div id="fileInput4" class="fileHidden">
            <input type="file" id="file4" name="files" />
            <input type="button" value="Töm" onclick="resetFileField(4)" />
        </div>
        <div id="fileInput5" class="fileHidden">
            <input type="file" id="file5" name="files" />
            <input type="button" value="Töm" onclick="resetFileField(5)" />
        </div>         
        <div id="fileInput6" class="fileHidden">
            <input type="file" id="file6" name="files" />
            <input type="button" value="Töm" onclick="resetFileField(6)" />
        </div>
        <div id="fileInput7" class="fileHidden">
            <input type="file" id="file7" name="files" />
            <input type="button" value="Töm" onclick="resetFileField(7)" />
        </div>
        <div id="fileInput8" class="fileHidden">
            <input type="file" id="file8" name="files" />
            <input type="button" value="Töm" onclick="resetFileField(8)" />
        </div>
        <div id="fileInput9" class="fileHidden">
            <input type="file" id="file9" name="files" />
            <input type="button" value="Töm" onclick="resetFileField(9)" />
        </div>

Сценарий:

function fileChangeHandler() {

    var hiddenClass = 'fileHidden';
    var visibleClass = 'fileVisible';

    var parentDiv = $(this).parent;
    var idNr = $(this).attr('id').replace('file', '');

    idNr++;

    if($(this).val().length > 0){

        for(var i = idNr; i < 10; i++){
            if($('#fileInput' + i).hasClass(visibleClass)){
                if($('#file' + i).val().length < 1){ return;}
            }
            else{
                    $('#fileInput' + i).attr('class' , visibleClass);
                    return;
            }
        }
    }
}

function resetFileField(id) {
    var hiddenClass = 'fileHidden';
    var visibleClass = 'fileVisible';
    var counter;

    $('#fileInput'+id).html($('#fileInput'+id).html());
    $('#file'+id).change(fileChangeHandler);

    for(var i = 9; i > -1 ;i--)
    {

        if(id != i)
        {
            if($('#fileInput' + i).hasClass(visibleClass)){
                if($('#file' + i).val().length < 1){
                    $('#fileInput' + i).attr('class', hiddenClass);
                }
            }
        }
    } 
}
* 1014лучшее решение?

Ответы [ 4 ]

10 голосов
/ 30 января 2011

У вас может быть контейнер div, который будет содержать поля ввода нового файла, и кнопка для добавления новых входных данных:

$('#addFile').click(function() {
    // when the add file button is clicked append
    // a new <input type="file" name="someName" />
    // to a filesContainer div
    $('#filesContainer').append(
        $('<input/>').attr('type', 'file').attr('name', 'someName')
    );
});
2 голосов
/ 30 января 2011

Да, вы можете просто добавить файл ввода в форму, как и любой другой элемент:

$("#theForm").append("<input type='file' name='foo'>");

Я мысль это звучит знакомо: [jquery] Как добавить загрузку файлов динамически?

0 голосов
/ 23 октября 2016

, если вы хотите иметь разные входные имена

var i;
$('#addFile').click(function() {
    i=i+1;
    $('#filesContainer').append(
        $('<input/>').attr('type', 'file').attr('name', 'file'+i)
    );
});
0 голосов
/ 24 ноября 2015

Другим вариантом, так как вы используете JQuery, является Bootstrap fileInput . Это позволяет загружать несколько изображений с одним элементом управления. У вас также есть дополнительные параметры, такие как разрешенные типы файлов, размер, высота, ширина и т. Д.

<script type="text/javascript">
    $("#postedImage").fileinput({
      uploadUrl: "/SomeUrl", // you must set this for ajax uploads
      maxFileCount: 10,
      enctype: "multipart/form-data",
      overwriteInitial: false
    });
</script>

<input id="postedImage" type="file" class="file" multiple>

Здесь - это ссылка для других загрузчиков, если вы заинтересованы.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...