web-dev-qa-db-fra.com

FileReader HTML5 comment retourner le résultat?

J'utilise JS FileReader. Je veux obtenir le résultat après l'opération de lecture de fichier et travailler avec ces données. FileReader est asynchrone et je ne sais pas quand le résultat est prêt. Comment le faire correctement?

$(document).ready(function(){
    $('#file_input').on('change', function(e){
        var res = readFile(this.files[0]);

        //my some manipulate with res

        $('#output_field').text(res);
    });
});

function readFile(file){
    var reader = new FileReader(),
        result = 'empty';

    reader.onload = function(e)
    {
        result = e.target.result;
    };

    reader.readAsText(file);

    //waiting until result is empty?

    return result;
}

http://jsfiddle.net/ub22m/4/

C'est montrer "vide".

Comment attendre que le "résultat" soit vide? Autrement?

29
trafalgarx

La lecture se produit de manière asynchrone . Vous devez fournir un rappel personnalisé onload qui définit ce qui doit se produire à la fin de la lecture:

$(document).ready(function(){
    $('#file_input').on('change', function(e){
        readFile(this.files[0], function(e) {
            // use result in callback...
            $('#output_field').text(e.target.result);
        });
    });
});

function readFile(file, onLoadCallback){
    var reader = new FileReader();
    reader.onload = onLoadCallback;
    reader.readAsText(file);
}

(Voir le Violon .)

Notez que readFile ne renvoie pas de valeur. Au lieu de cela, il accepte une fonction de rappel, qui se déclenche chaque fois que la lecture est terminée. L'opération $('#output_field').text est déplacée dans la fonction de rappel. Cela garantit que cette opération ne sera pas exécutée jusqu'à ce que le rappel du lecteur onload se déclenche, lorsque e.target.result Sera rempli.

La programmation avec des rappels est un peu difficile au début, mais elle est absolument nécessaire pour implémenter des fonctionnalités avancées.

48
apsillers

Voici le javascript:

$(document).ready(function() {
    $('#file_input').on('change', function(e) {

        function updateProgress(evt) {
            if (evt.lengthComputable) {
                // evt.loaded and evt.total are ProgressEvent properties
                var loaded = (evt.loaded / evt.total);
                if (loaded < 1) {
                    // Increase the prog bar length
                    style.width = (loaded * 200) + "px";
                }
            }
        }

        function loaded(evt) {
            // Obtain the read file data    
            var fileString = evt.target.result;
            // Handle UTF-16 file dump
            $('#output_field').text(fileString);
        }
        var res = readFile(this.files[0]);

        var reader = new FileReader();

        reader.readAsText(this.files[0], "UTF-8");

        reader.onprogress = updateProgress;
        reader.onload = loaded;


    });
});

function readFile(file) {
    var reader = new FileReader(),
        result = 'empty';

    reader.onload = function(e) {
        result = e.target.result;
    };

    reader.readAsText(file);

    return result;
}

Et bien sûr, la partie HTML:

<input type="file" id="file_input" class="foo" />
<div id="progBar" style="background-color:black;width:1px;"> </div>
<div id="output_field" class="foo"></div>

Semble fonctionner pour les fichiers * .txt.

Voir ce violon .

2
user554180

Utilisez une promesse pour encapsuler FileReader, puis utilisez await pour obtenir les résultats:

https://blog.shovonhasan.com/using-promises-with-filereader/

2
Aymon Fournier

cas d'utilisation FileReader

<html>
    <head>
        <link rel="stylesheet" href="http://code.jquery.com/ui/1.11.3/themes/smoothness/jquery-ui.css">
        <script src="http://code.jquery.com/jquery-1.10.2.js"></script>
        <script src="http://code.jquery.com/ui/1.11.3/jquery-ui.js"></script>
    </head>
    <body>
        <script>
            function PreviewImage() {
            var oFReader = new FileReader();
            oFReader.readAsDataURL(document.getElementById("uploadImage").files[0]);
            oFReader.onload = function (oFREvent) {
                var sizef = document.getElementById('uploadImage').files[0].size;
                document.getElementById("uploadPreview").src = oFREvent.target.result;
                document.getElementById("uploadImageValue").value = oFREvent.target.result; 
            };
        };
        jQuery(document).ready(function(){
            $('#viewSource').click(function ()
            {
                var imgUrl = $('#uploadImageValue').val();
                alert(imgUrl);
            });
        });
        </script>
        <div>
            <input type="hidden" id="uploadImageValue" name="uploadImageValue" value="" />
            <img id="uploadPreview" style="width: 150px; height: 150px;" /><br />
            <input id="uploadImage" style="width:120px" type="file" size="10" accept="image/jpeg,image/gif, image/png" name="myPhoto" onchange="PreviewImage();" />
        </div>
        <a href="#" id="viewSource">Source file</a>
    </body>
</html>
1
websky