Maison > développement back-end > tutoriel php > Plusieurs méthodes pour le téléchargement de fichiers asynchrone avec Ajax

Plusieurs méthodes pour le téléchargement de fichiers asynchrone avec Ajax

小云云
Libérer: 2023-03-17 16:00:01
original
1899 Les gens l'ont consulté

Le cœur d'Ajax est l'objet JavaScript XmlHttpRequest. Cet objet a été introduit pour la première fois dans Internet Explorer 5 et constitue une technologie qui prend en charge les requêtes asynchrones. En bref, XmlHttpRequest vous permet d'utiliser JavaScript pour envoyer des requêtes au serveur et gérer les réponses sans bloquer l'utilisateur. Ajax a peu de configuration requise en matière de serveur et peut servir des applications Java EE, des applications .NET et d'autres types d'applications. Grâce à Ajax, vous pouvez écrire du code JavaScript pour améliorer le HTML et créer une riche expérience utilisateur interactive.

1. Apprenez à connaître l'objet FormData

FormData est une nouvelle classe ajoutée à Html5, qui peut simuler les données de formulaire

Constructor

Explication

FormData (formulaire HTMLFormElement facultatif) (facultatif) Un élément de formulaire HTML qui peut contenir toute forme de contrôles de formulaire, y compris les zones de saisie de fichier

Méthode

void append(. Nom DOMString, valeur DOMString)

nom nom de l'élément de formulaire

valeur valeur à transmettre par l'élément de formulaire

<form name="myForm"  enctype="multipart/form-data">
    <input type="text" name="userName">
    <input type="file" name="img">
    <input type="button" id="btn" value="submit">
</form>
Copier après la connexion

Implémentation simple utilisant javascript

function upload() {    var userName = document.myForm.userName.value;    var img = document.myForm.img.files[0];    var fm = new FormData();
    fm.append(&#39;userName&#39;, userName);
    fm.append(&#39;img&#39;, img);    var request = new XMLHttpRequest();
    request.open(&#39;POST&#39;, &#39;submitform.php&#39;);
    request.send(fm);
}
Copier après la connexion

3. Utilisez Ajax pour implémenter

$(&#39;#btn&#39;).click(function () {    var userName = document.myForm.userName.value;    var img = document.myForm.img.files[0];    var fm = new FormData();
    fm.append(&#39;userName&#39;, userName);
    fm.append(&#39;img&#39;, img);
    $.ajax(
        {
            url: &#39;submitform.php&#39;,
            type: &#39;POST&#39;,
            data: fm,
            contentType: false, //禁止设置请求类型
            processData: false, //禁止jquery对DAta数据的处理,默认会处理
            //禁止的原因是,FormData已经帮我们做了处理
            success: function (result) {                //测试是否成功
                //但需要你后端有返回值
                alert(result);
            }
        }
    );
});
Copier après la connexion

4. Le plug-in ajaxfileupload.js implémente le téléchargement de fichiers Ajax

function upload(){
$.ajaxFileUpload({
        url: &#39;a.php&#39;, //用于文件上传的服务器端请求地址
        secureuri: false, //一般设置为false
        fileElementId: &#39;file&#39;, //文件上传空间的id属性  
        dataType: &#39;HTML&#39;, //返回值类型 一般设置为json
        success: function (data, status)  //服务器成功响应处理函数        {                
            $("#img1").attr("src", data);
            addI(data);
        },
        error: function (data, status, e)//服务器响应失败处理函数        {
            alert(e);
        }
    }   
);
}
Copier après la connexion

Pour PHP, vous pouvez utiliser les fichiers. tableau global pour obtenir les attributs du fichier, POST global Le tableau obtient la valeur de userName

Ci-dessus sont les différentes méthodes d'Ajax pour implémenter simplement le téléchargement de fichiers asynchrone. J'espère que cela sera utile à tout le monde.

Recommandations associées :

Méthode de traitement de rafraîchissement en temps réel Ajax

Plusieurs méthodes javascript pour implémenter l'ajax natif

Une brève introduction à ajax

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Étiquettes associées:
source:php.cn
Déclaration de ce site Web
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn
Tutoriels populaires
Plus>
Derniers téléchargements
Plus>
effets Web
Code source du site Web
Matériel du site Web
Modèle frontal