Przeciągnij i upuść wiele plików z oddzielnymi znacznikami wejściowymi

Dużo kodu, na tym przykładzie, ale chodzi o to:

Modyfikuję wtyczkę napisaną w PHP i javascript. Generuję kilka pól wejściowych, a javascript tworzy funkcję "przeciągnij i upuść".

Za każdym razem działa ona ok dla pojedynczych plików. (Przeciągnij i upuść 1 plik na sekcję do upuszczania plików, i powtórz)

Ale nie działa to dla wielu plików, ponieważ kończą się one w 1 polu wejściowym (przy dodawaniu atrybutu "wiele" do elementów wejściowych)

Zasadniczo linia:

document.querySelector('.file-input-element'+j).files = ev.dataTransfer.files;

Ten wiersz ustawia wartość na plik lub wiele plików, jest to obiekt typu: FileList.

Ale nie mogę uzyskać kodu javascript do podziału tego obiektu, czy to niemożliwe? W każdym razie, jeśli ktoś może mi w tym pomóc, to byłoby miło. Trochę na tym utknęło.

Podsumowując: Muszę przeciągnąć i upuścić wiele plików (obrazów) i umieścić je w osobnych elementach wejściowych.

<style>
    #drop_zone {
        width: 300px;
        height: 200px;
        border: 2px dotted red;
    }
</style>
<script>
    function dropHandler(ev) {
        console.log('File(s) dropped');

        // Prevent default behavior (Prevent file from being opened)
        ev.preventDefault();

        if (ev.dataTransfer.items) {
            // Use DataTransferItemList interface to access the file(s)
                    for (var j = 0; j < 10; j++) {
                        console.log(document.querySelector('.file-input-element'+j).files.length == 0);
                        if (document.querySelector('.file-input-element'+j).files.length == 0) {
                            // console.log(j+" is leeg dus vullen");
                            document.querySelector('.file-input-element'+j).files = ev.dataTransfer.files;
                            break; 
                        }
                    }

        } else {
            // Use DataTransfer interface to access the file(s)
            for (var i = 0; i < ev.dataTransfer.files.length; i++) {
                console.log('... file[' + i + '].name = ' + ev.dataTransfer.files[i].name);
            }
        }
    }
    function dragOverHandler(ev) {
        console.log('File(s) in drop zone'); 

        // Prevent default behavior (Prevent file from being opened)
        ev.preventDefault();
    }
</script>
<div class="fieldset marketplace-image">
    <h4 class="legend"><?php echo $this->__('Images'); ?></h4>
    <div id="drop_zone" ondrop="dropHandler(event);" ondragover="dragOverHandler(event);">
        <p>Drag one or more files to this Drop Zone ...</p>
    </div>
    <div id="marketplace_image_list">
        <?php for ($i=0; $i < 10; $i++): ?>
            <div class="market_place_add_image<?=$i;?>">
                <input class="file-input-element<?=$i;?>" type="file" name="image[<?=$i;?>][]">
            </div>
        <?php endfor; ?>
    </div>
</div>