Maison > Article > interface Web > Analysons comment uni-app implémente le téléchargement d'images
Cet article vous apporte des connaissances pertinentes sur uniapp, notamment sur la façon de télécharger des photos. Voyons comment le mettre en œuvre. J'espère qu'il sera utile à tout le monde.
Recommandation : "tutoriel uniapp"
Lors du développement de projets d'applications multiplateformes à l'aide de uni-app
, les exigences fonctionnelles pour le téléchargement de ressources telles que des images et des documents sont très courants : cliquez sur Le bouton du cadre photo vous permet de sélectionner les images à télécharger. Cliquez sur chaque image pour la prévisualiser. Cliquez sur l'icône de suppression de chaque image pour supprimer l'image correspondante. Les fonctions de base sont les suivantes : uni-app
开发跨平台App项目时,上传图片、文档等资源功能需求十分常见:点击相框按钮可选择图片上传,点击每一个图片可以进行预览,点击每个图片删除图标可删除对应图片。基本实现功能点如下:
- 本地相册选择图片或使用相机拍照上传图片;
- 可以预览选择上传的图片;
- 删除选错或不选的图片;
经过研读uni-app门户,官网推荐应用uni.chooseImage(OBJECT)
接口从本地相册选择图片或使用相机拍照。
对于门户提到的
选择照片大多为了上传,
uni ui
封装了更完善的uni-file-picker
组件,文件选择、上传到uniCloud
的免费存储和cdn中,一站式集成。强烈推荐使用。
本人并不认可,经过实践可知,该接口只能实现客户端将图片资源上传到uniCloud
后台服务器中,并不支持本地服务器,故并不满足功能需求,需谨慎使用。
项目实现页面大致逻辑如下,完整页面实现逻辑可移步《Uni-app 实现图片上传、删除、预览、压缩》下载。
视图渲染
<template> <view> <!-- 上传图片 --> <view> <view> <image></image> <view> <uni-icons></uni-icons> </view> </view> <view> <image></image> </view> <!-- 图片数量提示 --> <view>{{curTotal}}/3</view> </view></view></template>
JS逻辑层-图片上传
// 图片选择上传upload() { var _self = this; // 图片选择,只支持一次选择一张图片 uni.chooseImage({ count: 1, sizeType: ['original', 'compressed'], //可以指定是原图还是压缩图,默认二者都有 sourceType: ['album', 'camera'], //从相册、相机选择 success: function (res) { console.log('res:', res) _self.curTotal++; _self.imgList.push(res.tempFilePaths[0]); const tempFilePaths = res.tempFilePaths[0]; // 图片上传 const uploadTask = uni.uploadFile({ url : 'http://22.189.25.91:9988/admin/sys-file/upload', // post请求地址 filePath: tempFilePaths, name: 'file', // 待确认 header: { 'Content-Type': 'multipart/form-data', 'Authorization': getApp().globalData.token || 'Basic YXBwOmFwcA==' }, success: function (uploadFileRes) { console.log('Success:', uploadFileRes); _self.imgsID.push(JSON.parse(uploadFileRes.data).data.fileId); console.log('_self.imgsID:', _self.imgsID) }, fail: function (uploadFileFail) { console.log('Error:', uploadFileFail.data); }, complete: ()=> { console.log('Complete:'); } }); }, error : function(e){ console.log(e); } });}
JS逻辑层-图片预览
/** * 图片预览 * @param {Object} i 选择的图片索引 * @param {Object} imgList 自行封装的图片数组 */viewImage(i, imgList) { let imgurl = [] imgList.forEach(item => imgurl.push(item)) uni.previewImage({ urls: imgurl, current: imgList[i] });}
JS逻辑层-图片删除
/** 图片删除 * @param {Object} i 删除图片的索引 * @param {Object} imgList 自行封装的图片数组 */delImg(i, imgList, imgsID) { uni.showModal({ title: '提示', content: '确定要删除照片吗?', cancelText: '取消', confirmText: '确定', success: res => { if(res.confirm) { imgList.splice(i, 1); imgsID.splice(i, 1); this.curTotal--; } } })}}
JS逻辑层-图片压缩
// src: 压缩转换原始图片的路径// _this: 当前的this,如果不想传递this可将该函数改为箭头函数// callback: 回调函数,详情chooseImage方法function compressImage(src, _this, callback) { var dstname = "_doc/IMG-" + (new Date()).valueOf() + ".jpg"; //设置压缩后图片的路径 var width, height, quality; width = "80%"; height = "80%"; quality = 80; // 具体情况可查看HTML5+文档 ===> http://www.html5plus.org/doc/zh_cn/zip.html#plus.zip.compressImage plus.zip.compressImage({ src: src, dst: dstname, overwrite: true, quality: quality, width: width, height: height }, function(event) { callback(event.target, dstname, _this); }, function(error) { return src; });}
注意:在图片上传之前进行图片压缩,由于图片压缩时间过长,应采用
await
上传图片之前先压缩,否则上传会比压缩先执行。
应用实现效果如下:
拍照或从相册选择图片/上传一张图片
上传3张图片/删除图片
客户端通过uni.chooseImage()
方法选择本地相册图片或者拍照,获取到一个本地资源的临时文件路径后,然后以 POST
请求方式通过uni.uploadFile()
方法将本地资源上传到开发者服务器,POST
请求中 content-type
为 multipart/form-data
。
图片选择应用uni.chooseImage()
实现,请谨慎使用uni ui
封装的所谓更完善的uni-file-picker
组件,其将资源文件选择、上传到uniCloud
的免费存储和cdn
中,一站式集成,个人无法修改。强烈推荐不使用!
图片上传应用uni.uploadFile()
实现,上传成功后回调函数返回的uploadFileRes.data
是个String
类型,转对象的时候需要应用JSON.parse()
解析。
JSON.parse(uploadFileRes.data).data.fileId)
{ "data": "{\"code\":0,\"msg\":null,\"data\":{\"bucketName\":\"cicc\",\"fileName\":\"5aaa39d669224ffb869b60d245b0751a.jpg\",\"original\":\"1644999553865_mmexport1644913914292.jpg\",\"url\":\"/admin/sys-file/cicc/5aaa39d669224ffb869b60d245b0751a.jpg\",\"fileId\":\"172\"}}", "statusCode": 200, "errMsg": "uploadFile:ok"}
uni.uploadFile()
OBJECT 参数说明部分中name
属性为待上传文件对应的 key
, 开发者在服务器端通过这个 key
可以获取到文件二进制内容,前后端对于该key应保持一致,否则会导致服务无法请求。
图片预览应用uni.previewImage()
2. Projet de combat réelAprès avoir étudié le portail uni-app, le site officiel recommande l'application du
- Sélectionnez des photos de l'album local ou utilisez l'appareil photo pour prendre des photos et télécharger des photos ;
- Vous pouvez prévisualiser les photos téléchargées sélectionnées
- ; Supprimez les images mal sélectionnées ou non sélectionnées ;
uni.chooseImage(OBJECT)
interface pour sélectionner des photos de l'album local ou utiliser l'appareil photo pour prendre des photos. 🎜🎜Comme mentionné sur le portail🎜🎜principalement pour sélectionner des photos à télécharger,🎜Je ne suis pas d'accord avec cela. Grâce à la pratique, nous savons que cette interface ne peut permettre au client que de télécharger des ressources d'image sur le serveur backenduni ui
encapsule un composantuni-file-picker
plus complet pour la sélection et le téléchargement de fichiers. Accédez au stockage gratuit et au CDN deuniCloud
pour une intégration unique. Fortement recommandé. 🎜
uniCloud
. Elle ne prend pas en charge les serveurs locaux. , il ne répond donc pas aux exigences de fonctionnalité, veuillez l'utiliser avec prudence. 🎜🎜La logique générale de la page de mise en œuvre du projet est la suivante. La logique complète de mise en œuvre de la page peut être téléchargée depuis "Uni-app réalise le téléchargement, la suppression, la prévisualisation et la compression des images". 🎜🎜Rendu des vues🎜rrreee🎜Couche logique JS - Téléchargement d'images🎜rrreee🎜Couche logique JS - Aperçu de l'image🎜rrreee🎜JS Couche logique - suppression d'image🎜rrreee🎜Couche logique JS - compression d'image🎜rrreee🎜Remarque : la compression d'image est effectuée avant de télécharger l'image car le temps de compression de l'image est trop long. , vous devez utiliser await
Compresser l'image avant de la télécharger, sinon le téléchargement sera effectué avant la compression. 🎜
🎜L'effet d'application est le suivant :POST
via uni. La méthode uploadFile( )
télécharge les ressources locales sur le serveur du développeur, et le content-type
dans la requête POST
est multipart/form-data code>. 🎜<h3>3.2 Notes</h3>
<ul><li>🎜La sélection d'images est implémentée à l'aide de <code>uni.chooseImage()
, veuillez utiliser ce qu'on appelle le package encapsulé par uni ui avec prudence Un composant <code>uni-file-picker
plus complet, qui sélectionne et télécharge les fichiers de ressources vers le stockage gratuit de uniCloud
et cdn
, guichet unique intégré et non modifiable par des particuliers. Fortement déconseillé de l'utiliser ! 🎜🎜uni.uploadFile()
est implémentée. Le uploadFileRes.data
renvoyé par la fonction de rappel une fois le téléchargement réussi est de type String
, vous devez utiliser JSON.parse()
pour analyser lors de la conversion d'objets. 🎜rrreeerrreee🎜uni.uploadFile()
L'attribut name
dans la section de description du paramètre OBJECT est la clé
correspondant au fichier à être téléchargé, développeur Le contenu binaire du fichier peut être obtenu via cette clé
côté serveur. Le front-end et le back-end doivent être cohérents avec cette clé, sinon le service ne pourra pas demander. . uni.previewImage()
est implémentée sans aucun piège. Vous pouvez l'utiliser selon les paramètres du portail en fonction de vos besoins. 🎜🎜🎜🎜Recommandé : "🎜Tutoriel d'apprentissage uniapp🎜"🎜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!