Maison > interface Web > Questions et réponses frontales > En une heure, je vous emmène résumer la méthode de téléchargement de fichiers sur le front-end (organisé et partagé)

En une heure, je vous emmène résumer la méthode de téléchargement de fichiers sur le front-end (organisé et partagé)

WBOY
Libérer: 2022-02-08 17:33:31
avant
15849 Les gens l'ont consulté

Cet article vous apporte des connaissances pertinentes sur les fichiers de téléchargement front-end, y compris le téléchargement en mode de développement traditionnel, le téléchargement séparé front-end et back-end, le téléchargement ajax et d'autres problèmes connexes. J'espère qu'il sera utile à tout le monde.

En une heure, je vous emmène résumer la méthode de téléchargement de fichiers sur le front-end (organisé et partagé)

Télécharger des fichiers

Il y aura de nombreuses exigences de téléchargement de fichiers dans le projet, telles que : téléchargement d'avatar, fichiers de table, documents Word, etc...

Éléments de formulaire requis pour le téléchargement :

<input>
Copier après la connexion

Lors du téléchargement de fichiers ,
1 .Le formulaire doit être une demande de publication
2. Le formulaire doit déclarer de ne pas encoder les données - enctype=multipart/form-data

Le format des données transmises est sous forme de paires clé-valeur, et le les données sont toutes des types de données js, mais les fichiers sont Lors de la transmission, il n'y a que deux formes de transmission :

  1. Décrire un fichier sous forme de chaîne
  2. Décrire un fichier sous la forme d'un flux de fichiers

Développement traditionnel mode upload

Développement mixte front-end et back-end

Le téléchargement dans le modèle de développement traditionnel nécessite de transférer les fichiers sélectionnés dans le formulaire vers le backend, et de laisser le backend faire le téléchargement :

Copier après la connexion
Copier après la connexion
Copier après la connexion
    <input>     <input>

À ce moment, le formulaire doit avoir l'attribut enctype. La description de cet attribut est la suivante :

En une heure, je vous emmène résumer la méthode de téléchargement de fichiers sur le front-end (organisé et partagé)

Après avoir cliqué sur le bouton de téléchargement, le backend téléchargera le fichier. Prenons PHP comme exemple :

echo "上传文件名: " . $_FILES["avatar"]["name"] . "<br>";  上传文件的名称
echo "文件类型: " . $_FILES["avatar"]["type"] . "<br>";  上传文件的类型
echo "文件大小: " . ($_FILES["avatar"]["size"] / 1024) . " kB<br>";  上传文件的大小,以字节计
echo "文件临时存储的位置: " . $_FILES["avatar"]["tmp_name"];  存储在服务器的文件的临时副本的名称
echo $_FILES["file"]["error"]  由文件上传导致的错误代码
Copier après la connexion

Enregistrez le fichier sur le serveur. :

move_uploaded_file($_FILES["avatar"]["tmp_name"], "upload/" . $_FILES["avatar"]["name"]);
echo "文件存储在: " . "upload/" . $_FILES["avatar"]["name"];
Copier après la connexion

Dans le développement réel, afin d'améliorer l'efficacité, le développement de séparation front-end et back-end est généralement utilisé.

Téléchargement séparé du front-end et du back-end

Le front-end est le front-end, le back-end est le back-end, et enfin le document d'interface est utilisé pour l'amarrage - la technologie de base est ajax

Le front-end et le back-end sont développés séparément, et la principale technologie utilisée est ajax. Le téléchargement peut également être effectué en utilisant ajax.

FormData est un constructeur intégré à js, ​​et l'objet construit peut identifier les informations du fichier.

Utilisation :

Construisez l'objet FormData, ajoutez des informations de fichier à l'objet FormData, puis téléchargez-le.

Les informations sur le fichier se trouvent dans le contrôle de sélection de fichier : form.files

Exemple :

    <input>
    <input><script>document.querySelector(&#39;[type="button"]&#39;).onclick = function(){
	 console.log(document.querySelector(&#39;[type="file"]&#39;).files)}</script>
Copier après la connexion

En une heure, je vous emmène résumer la méthode de téléchargement de fichiers sur le front-end (organisé et partagé)

L'objet FormData a une fonctionnalité après avoir ajouté les informations sur le fichier, vous ne pouvez pas voir les informations sur le fichier lors de l'impression directe dont vous avez besoin. à utiliser pour le parcours pour ce faire. Voir :

var formdata = new FormData();var fileinfo = document.querySelector('[type="file"]').files[0];formdata.append('avatar',fileinfo) / 将文件信息添加到FormData对象中
console.log(formdata)for(var v of formdata){
    console.log(v)}
Copier après la connexion

En une heure, je vous emmène résumer la méthode de téléchargement de fichiers sur le front-end (organisé et partagé)

Vous pouvez également ajouter d'autres données à l'objet FormData et les soumettre ensemble :

formdata.append('avatar',fileinfo)formdata.append('age',12)for(var v of formdata){
    console.log(v)}
Copier après la connexion

En une heure, je vous emmène résumer la méthode de téléchargement de fichiers sur le front-end (organisé et partagé)

Pour supprimer une donnée de l'objet FormData, utilisez :

formdata.delete(键)
Copier après la connexion

Parfois, nous sommes dans un formulaire. Plusieurs fichiers doivent être téléchargés. Pour le moment, il n'est pas nécessaire d'ajouter des informations de fichier à FormData. Lors de la construction de l'objet FormData, l'intégralité de l'objet de formulaire peut être transmise. il reconnaîtra automatiquement toutes les données :

Copier après la connexion
Copier après la connexion
Copier après la connexion
    <input>     <input>     <input>
<script>document.querySelector(&#39;[type="button"]&#39;).onclick = function(){ var formdata = new FormData(document.querySelector(&#39;form&#39;)); for(var v of formdata){ console.log(v) }}</script>

En une heure, je vous emmène résumer la méthode de téléchargement de fichiers sur le front-end (organisé et partagé)

Lors du téléchargement à l'aide de FormData Lors de la transmission de l'objet FormData en tant que données, il n'est pas nécessaire de modifier l'en-tête de la requête, le navigateur le modifiera automatiquement.

À l'heure actuelle, un téléchargement séparé du front-end et du back-end a été mis en œuvre, mais les projets normaux auront une fonction pour prévisualiser les images.

Nous pouvons laisser le backend transmettre le nom du fichier téléchargé au frontend après le téléchargement, et laisser le frontend restituer le chemin de l'image renvoyé.

Mais ceci concerne la prévisualisation après le téléchargement. Supposons qu'après avoir sélectionné le fichier, nous voulons voir si le fichier doit être téléchargé, c'est-à-dire que si nous voulons prévisualiser avant le téléchargement, il n'y a toujours aucun moyen d'y parvenir.

Nous pouvons utiliser le FileReader fourni par H5 pour lire le fichier et le prévisualiser, puis décider de le télécharger ou non.

téléchargement ajax

Après les téléchargements ajax

 var xhr = new XMLHttpRequest;
    xhr.onreadystatechange = function(){
        if(xhr.readyState === 4){
            if(xhr.status>=200 && xhr.status<p>Mettez les données du fichier dans l'envoi pour transmission<br> Vous devez utiliser le constructeur FormData fourni par H5 - utilisé pour identifier les informations du fichier</p><pre class="brush:php;toolbar:false">var fd = new FormData()
Copier après la connexion

Mettez les informations du fichier dans le fd object Medium - Utilisation de la méthode append de fd

Où sont les informations sur le fichier ? La méthode

var file = document.querySelector('[type="file"]')
    // console.dir(file);
    var fileinfo = file.files[0] / 文件信息
Copier après la connexion

append consiste à placer le fichier dans cet objet. L'objet nécessite des paires clé-valeur. Le paramètre 1 est la clé et le paramètre 2 est les informations du fichier.

fd.append('avatar',fileinfo)
Copier après la connexion

fd a une fonctionnalité qui consiste à l'imprimer directement sans. voir le contenu. Le contenu doit être parcouru pour voir les données - vous devez utiliser for of

for(var value of fd){
         console.log(value);
    }
Copier après la connexion

fd En plus d'ajouter des informations sur le fichier, vous pouvez également ajouter des données

.
fd.append('username',document.querySelector('[name="username"]').value)
Copier après la connexion

上传文件的时候,利用FormData,里面就有了数据和文件信息,其实最终文件和数据以二进制数据流进行传送的,不需要设置请求头,因为ajax会自动调整

文件数据其实就是fd

php:

现在能打印出数据,文件存到了临时目录中
上传就是将临时文件移动到服务器中

header("content-type:text/html;charset=utf8");echo "<pre class="brush:php;toolbar:false">";print_r($_FILES);move_uploaded_file($_FILES['avatar']['tmp_name'],'./upload/'.$_FILES['avatar']['name']);// echo '上传成功';echo './upload/'.$_FILES['avatar']['name'];
 echo "<script>
     alert(&#39;上传成功&#39;)
     location.assign(&#39;./1-上传表单.html&#39;)</script>
Copier après la connexion

ajax 上传前:

当文件选择器中的数据发生了变化就要读取并预览
读取并预览 - 借助H5提供的FileReader - 读取文件是异步读取
构造函数需要new

document.querySelector('[type="file"]').onchange = function(){var fr = new FileReader();
Copier après la connexion

readAsArrayBuffer - 将数据读取成一个Buffer数组

var fileinfo = this.files[0]
Copier après la connexion

参数要一个文件对象 - 结果是一个buffer

fr.readAsArrayBuffer(fileinfo)
Copier après la connexion

参数要一个文件对象 - 结果是一个二进制数据 - 适用于多媒体文件

fr.readAsBinaryString(fileinfo)
Copier après la connexion

结果是一个可以当做路径使用的数据 - base64字符串 - 适用于图片

fr.readAsDataURL(fileinfo)
Copier après la connexion

在load事件中,读取完成后获取读取出来的数据
load事件在读取完成的时候触发

fr.onload = function(){
        / result属性是读取出来的内容        / console.log(fr.result);
        / 创建img标签        var img = document.createElement('img')
        img.src = fr.result;
        document.body.appendChild(img)
Copier après la connexion

FileReader读取文件

FileReader也是js内置的一个构造函数,主要功能是用来读取文件,读取文件为异步读取。

var fr = new FileReader()  创建读取对象// 该对象的读取方法:fr.readAsDataUrl(文件信息)  将文件读取为base64字符串 - 通常用于图片文件,读取结果可以作为图片的src使用
fr.readAsArrayBuffer(文件信息)  将文件读取为二进制数据流 - 通常用于多媒体文件
fr.readAsText(文件信息)  将文件读取为字符串 - 通常用于文档文件
Copier après la connexion

对象监听的事件:

abort事件:在读取被中断的时候触发
error事件:读取发生错误的时候触发
load事件:在读取完成的时候触发 - 常用语读取完成后获取数据
loadstart事件:在读取开始的时候触发
loadend事件:在读取结束的时候触发
progress事件:在读取过程中触发

例:

fr.onload = function(){
  读取结果为:对象.result 或 事件对象.target.result
    console.log(fr.result)  此时这个数据就可以作为img的src进行图片预览}
Copier après la connexion

base64是指:小写字母+大写字母+数字+加号+等于号 共64个字符

jquery上传

data位置就直接写formData就好了

设置一个content-type为false表示jquery不要设置请求头

设置一个processData为false,表示query不要修改数据格式

Copier après la connexion
Copier après la connexion
Copier après la connexion
    <input>     <input>     
    <input>

我们可以在new的时候,将表单元素放在构造函数中 - 默认能将表单中的数据,添加到这个对象中

$('[type="button"]').click(function()
    var fd = new FormData($('form')[0])

    $.ajax({
        url:"2-upload.php",
        method:"post",
         jquery上传用 FormData
        data:fd,
        contentType:false,  不让jQuery的ajax修改请求头
        processData:false,  不让jquery的ajax编码数据        success:res=>{
            console.log(res);
        }
        
    })})
Copier après la connexion

webWorker

大量运算的代码,可以作为一个异步线程执行
需要将这段代码单独放在一个文件中
需要new一个worker对象 - 这个构造函数需要在服务器环境中运行

woker需要一个事件,当文件完成以后获取里面的数据
可以在事件中,接收到文件中导出的数据

woker.onmessage = function(e){
    数据就在事件对象的data属性中
    console.log(e.data);}
Copier après la connexion

当业务逻辑需要的计算量比较大的时候,同步代码会阻塞下面的代码继续执行,此时需要将这个大计算量的代码另外开辟一个新的线程进行执行,这个线程也是异步执行的,但需要将在新线程中执行的代码单独放在一个js文件中,使用方式:

var w = new Worker(需要异步执行的js文件)
Copier après la connexion

如果在主线程中需要这个线程中返回的数据,在这个线程中使用postMessage来返回:

postMessage(数据)
Copier après la connexion

主线程中接收返回出来的数据:

w.onmessage = function(e){
    e.data // 是异步线程中返回出来的数据}
Copier après la connexion

离线缓存

离线缓存的作用:在马上断网之后,依旧可以访问到缓存下来的文件。比较鸡肋。该技术在2020年8月已经被弃用了。

使用方式:

使用规则        1. 需要你自定义一个 .manifest 文件        2. 再你书写 html 文件的时候
          => 如果这个 html 文件需要缓存规则
          => 再 html 标签上添加一个 manifest 属性
          => 值就写你的缓存规则文件        3. 第一次打开页面的时候
          => 就会按照你书写的缓存规则去缓存文件
Copier après la connexion

例:

第一行必须要写上
CACHE MANIFEST
以注释的形式书写一个版本号
app version 1.0

表示你要缓存的文件
CACHE:
./index.html
./css/index.css

表示必须需要网络环境才可以请求的文件
一般我们会书写 星号(*), 表示除了 CACHE 里面书写的文件, 其他的去过没有网络环境就报错
NETWORK:
*

当你再一个离线环境下访问一些没有的页面的时候
使用一个什么内容替代
FALLBACK:

  • ./404.html

事件循环面试题:

<script>console.log(1)setTimeout(()=>{ console.log(2) },0) new Promise(resolve=>{
    console.log(3)
    resolve()}).then(()=>{ 
    console.log(4)})setTimeout(()=>{ 
    console.log(5)
    new Promise(resolve=>{
        console.log(6)
        setTimeout(()=>{ 
            console.log(7)
        })
        resolve()
    }).then(()=>{ 
        console.log(8)
    })},500)new Promise(resolve=>{
    console.log(9)
    resolve()}).then(()=>{ 
    console.log(10)
    setTimeout(()=>{ 
        console.log(11)
    },0)})console.log(12)</script>
Copier après la connexion

答案:1 3 9 12 4 10 2 11 5 6 8 7

更多编程相关知识,请访问:编程视频!!

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:csdn.net
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