Taro@3.x+Vue@3.x+TS开发微信小程序,上传文件

2024-04-28 21:28

本文主要是介绍Taro@3.x+Vue@3.x+TS开发微信小程序,上传文件,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

参考文档

  • Taro官网
  • 微信官方文档
  • 微信公众平台
  • Nut UI

使用 <nut-uploader/> 组件,并自定义上传方式

请添加图片描述

<script setup lang="ts">
import { ref, reactive } from 'vue'
import Taro from '@tarojs/taro'
import { encryptData } from '@/http/encrypt'const url = {upload: '/file/upload'
}
const uploadUrl = process.env.TARO_APP_PROXY + url.upload
interface Image {name: stringurl: string
}
interface FormType {images: Image[][key: string]: any
}
const formData = reactive<FormType>({images: []
})
const uploadFileList = ref<any[]>([])
function uploadFile (src, taroUploadFile, options) {const fs = Taro.getFileSystemManager()fs.getFileInfo({filePath: src,success: (res) => {console.log('getFileInfo res', res)}})fs.readFile({ // 读取本地文件内容。单个文件大小上限为100MfilePath: src, // 要读取的文件的路径 (本地路径)encoding: 'base64', // 指定读取文件的字符编码,如果不传 encoding,则以 ArrayBuffer 格式读取文件的二进制内容success: (res) => {console.log('readFile', res)const data = {decodeFile: res.data, // 以base64字符串上传fileFormat: options.taroFilePath.slice(options.taroFilePath.lastIndexOf('.') + 1)}const uploadData = encryptData(data, 'post') // 接口传参加密,不加密可忽略const uploadTask = taroUploadFile({url: options.url,filePath: src,name: options.name,fileType: options.fileType,header: {'Content-Type': 'application/x-www-form-urlencoded'},formData: uploadData,success: (response: { errMsg; statusCode; data }) => {if (options.xhrState == response.statusCode) {options.onSuccess?.(response, options)} else {options.onFailure?.(response, options)}},fail: (e) => {options.onFailure?.(e, options)}})options.onStart?.(options)uploadTask.progress((res) => {options.onProgress?.(res, options)// console.log('上传进度', res.progress);// console.log('已经上传的数据长度', res.totalBytesSent);// console.log('预期需要上传的数据总长度', res.totalBytesExpectedToSend);})},fail: (err) => {console.error(err)}})
}
function beforeXhrUpload (taroUploadFile, options) {console.log('before taroUploadFile', taroUploadFile)console.log('before options', options)Taro.compressImage({src: options.taroFilePath,quality: 80,compressedWidth: 300,success: (res: any) => {console.log('compress', res)uploadFile(res.tempFilePath, taroUploadFile, options)},fail: (err: any) => {console.log('compress err', err)abortUpload(taroUploadFile, options)}})
}
function abortUpload (taroUploadFile, options) {const uploadTask = taroUploadFile(options)uploadTask.abort()
}
function onStart (options) {console.log('start options', options)
}
function onDelete ({index}) {console.log('delete', index)formData.images.splice(index, 1)console.log('images', formData.images)console.log('uploadFileList', uploadFileList.value)
}
function onOversize (files) {console.log('oversize files', files)
}
function onSuccess ({data}) {console.log('success', data)const res = JSON.parse(data.data)console.log('res', res)if (res.message.code === 0) {formData.images.push({name: res.data.fileUrl.split('/').pop(),url: res.data.fileUrl})console.log('images', formData.images)} else {Taro.showToast({title: res.message.message,icon: 'none',mask: true,duration: 2000})}console.log('uploadFileList', uploadFileList.value)
}
function onFailure ({data}) {console.log('failure', data)if (data !== undefined) {Taro.showToast({title: '上传失败',icon: 'none',mask: true,duration: 2000})uploadFileList.value.pop()console.log('uploadFileList', uploadFileList.value)}
}
</script>
<template><view><view class="m-image-wrap"><view class="u-head">上传照片<text class="u-tip">(最多支持3张)</text></view><view class="m-upload-wrap"><nut-uploaderv-model:file-list="uploadFileList":url="uploadUrl"multiple:maximize="10 * 1024 * 1024":maximum="3":media-type="['image']":size-type="['compressed']":before-xhr-upload="beforeXhrUpload"@start="onStart"@delete="onDelete"@oversize="onOversize"@success="onSuccess"@failure="onFailure" /></view></view></view>
</template>
<style lang="less">
.m-image-wrap {padding: 24px 28px 40px;margin: 20px auto;width: 690px;height: 349px;background: #FFFFFF;border-radius: 12px;.m-upload-wrap {margin-top: 40px;.nut-uploader__preview {margin-bottom: 0;margin-right: 0;&:not(:last-child) {margin-right: 17px;}}}
}
</style>

这篇关于Taro@3.x+Vue@3.x+TS开发微信小程序,上传文件的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/944302

相关文章

Python38个游戏开发库整理汇总

《Python38个游戏开发库整理汇总》文章介绍了多种Python游戏开发库,涵盖2D/3D游戏开发、多人游戏框架及视觉小说引擎,适合不同需求的开发者入门,强调跨平台支持与易用性,并鼓励读者交流反馈以... 目录PyGameCocos2dPySoyPyOgrepygletPanda3DBlenderFife

使用Python开发一个Ditto剪贴板数据导出工具

《使用Python开发一个Ditto剪贴板数据导出工具》在日常工作中,我们经常需要处理大量的剪贴板数据,下面将介绍如何使用Python的wxPython库开发一个图形化工具,实现从Ditto数据库中读... 目录前言运行结果项目需求分析技术选型核心功能实现1. Ditto数据库结构分析2. 数据库自动定位3

Django开发时如何避免频繁发送短信验证码(python图文代码)

《Django开发时如何避免频繁发送短信验证码(python图文代码)》Django开发时,为防止频繁发送验证码,后端需用Redis限制请求频率,结合管道技术提升效率,通过生产者消费者模式解耦业务逻辑... 目录避免频繁发送 验证码1. www.chinasem.cn避免频繁发送 验证码逻辑分析2. 避免频繁

Spring Boot集成/输出/日志级别控制/持久化开发实践

《SpringBoot集成/输出/日志级别控制/持久化开发实践》SpringBoot默认集成Logback,支持灵活日志级别配置(INFO/DEBUG等),输出包含时间戳、级别、类名等信息,并可通过... 目录一、日志概述1.1、Spring Boot日志简介1.2、日志框架与默认配置1.3、日志的核心作用

PyQt5 GUI 开发的基础知识

《PyQt5GUI开发的基础知识》Qt是一个跨平台的C++图形用户界面开发框架,支持GUI和非GUI程序开发,本文介绍了使用PyQt5进行界面开发的基础知识,包括创建简单窗口、常用控件、窗口属性设... 目录简介第一个PyQt程序最常用的三个功能模块控件QPushButton(按钮)控件QLable(纯文本

从入门到精通详解LangChain加载HTML内容的全攻略

《从入门到精通详解LangChain加载HTML内容的全攻略》这篇文章主要为大家详细介绍了如何用LangChain优雅地处理HTML内容,文中的示例代码讲解详细,感兴趣的小伙伴可以跟随小编一起学习一下... 目录引言:当大语言模型遇见html一、HTML加载器为什么需要专门的HTML加载器核心加载器对比表二

基于Python开发一个图像水印批量添加工具

《基于Python开发一个图像水印批量添加工具》在当今数字化内容爆炸式增长的时代,图像版权保护已成为创作者和企业的核心需求,本方案将详细介绍一个基于PythonPIL库的工业级图像水印解决方案,有需要... 目录一、系统架构设计1.1 整体处理流程1.2 类结构设计(扩展版本)二、核心算法深入解析2.1 自

Spring Boot 结合 WxJava 实现文章上传微信公众号草稿箱与群发

《SpringBoot结合WxJava实现文章上传微信公众号草稿箱与群发》本文将详细介绍如何使用SpringBoot框架结合WxJava开发工具包,实现文章上传到微信公众号草稿箱以及群发功能,... 目录一、项目环境准备1.1 开发环境1.2 微信公众号准备二、Spring Boot 项目搭建2.1 创建

golang程序打包成脚本部署到Linux系统方式

《golang程序打包成脚本部署到Linux系统方式》Golang程序通过本地编译(设置GOOS为linux生成无后缀二进制文件),上传至Linux服务器后赋权执行,使用nohup命令实现后台运行,完... 目录本地编译golang程序上传Golang二进制文件到linux服务器总结本地编译Golang程序

使用Docker构建Python Flask程序的详细教程

《使用Docker构建PythonFlask程序的详细教程》在当今的软件开发领域,容器化技术正变得越来越流行,而Docker无疑是其中的佼佼者,本文我们就来聊聊如何使用Docker构建一个简单的Py... 目录引言一、准备工作二、创建 Flask 应用程序三、创建 dockerfile四、构建 Docker