vue3.0 移动端二次封装van-uploader实现上传图片(vant组件库)
更新时间:2022年05月21日 10:25:16 作者:Smile_zxx
这篇文章主要介绍了vue3.0 移动端二次封装van-uploader上传图片组件,此功能最多上传6张图片,并可以实现本地预览,实现代码简单易懂,需要的朋友可以参考下
1、前提:业务需求,最多上传6张图片,并可以实现本地预览
2、解决方法:使用vant组件库中的van-uploader实现
3、代码实现
template
<div class="upload-oss"> <van-uploader :after-read="onRead" :before-read="beforeRead" :accept="fileType" v-model="fileList" multiple :max-count="maxCount" :max-size="maxSize" @oversize="onOversize" > </van-uploader> </div>
js实现
import { moment } from '@/common' const emit = defineEmits(['update:fileList']) defineProps({ maxCount: { // 图片张数 type: Number, default: 6 }, maxSize: { // 图片大小 type: Number, default: 500 * 1024 }, fileType: { // 文件类型 type: String, default: "image/*" }, fileList: { //已上传的文件列表 type: Array, default: (()=>{ return [] }) }, }) // 文件大小超过限制时触发 function onOversize(file){ console.log("请上传小于10M的图片") } // 上传前置处理 function beforeRead (file) { if(Array.isArray(file)) { file.forEach(item => { if (item.type !== 'image/jpeg') { console.log("请上传 image 格式图片") return false } }) if (file.type !== 'image/jpeg') { console.log("请上传 image 格式图片") return false } } return true } async function onRead(file){ let content = file let forms = new FormData() // 判断当前上传几张图,一张以上则为数组结构 if(Array.isArray(content)) { content.forEach(item => { forms.append("file",item.file) forms.append('filePath', `pc/client-${moment().format('YYYY-MM-DD')}/`) }) }else{ forms.append("file", content.file) forms.append('filePath', `pc/client-${moment().format('YYYY-MM-DD')}/`) } let res = await axios.post({ 、、、、发起后端上传图片接口请求 }) if (res) { emit("update:fileList", res.data) } }
4、实现的效果图
到此这篇关于vue3.0 移动端二次封装van-uploader上传图片组件的文章就介绍到这了,更多相关vue3.0 van-uploader上传图片组件内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
解决v-for中使用v-if或者v-bind:class失效的问题
今天小编就为大家分享一篇解决v-for中使用v-if或者v-bind:class失效的问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧2018-09-09在移动端使用vue-router和keep-alive的方法示例
这篇文章主要介绍了在移动端使用vue-router和keep-alive的方法示例,vue-router与keep-alive提供的路由体验与移动端是有一定差别的,感兴趣的小伙伴们可以参考一下2018-12-12
最新评论