Vue3使用van-uploader遇到某些安卓机型(小米、vivo、oppo等等)无法上传文件解决方案

概要

最近在做移动端时遇到个上传附件的需求是只能上传以下类型的文件:

  • 图片文件(jpeg、jpg、png)
  • 文档文件(pdf、txt、doc、docx、xls、xlsx、ppt、pptx)

在这里我用的是有赞的上传组件,但是上线后,发现苹果手机没有问题,反而一些安卓手机都出现了问题,在经过几次的修改,调整了限制文件类型后,就正常上传了!!!可喜可贺,以此记录下解决方法,希望能够帮到大家。

对应的附件格式

  1. 图片格式(限制png、jpeg、png)

accept=“image/jpeg,image/png,image/jpg”
jpeg:image/jpeg
png:image/png
jpg:image/jpg

  1. 文件格式(限制pdf、doc、docx、ppt、pptx、xls、xlsx)

pdf:application/pdf
doc:application/msword
docx: application/vnd.openxmlformats-officedocument.wordprocessingml.document
ppt:application/vnd.ms-powerpoint
pptx:application/vnd.openxmlformats-officedocument.presentationml.presentation
xls: application/vnd.ms-excel
xlsx:application/vnd.openxmlformats-officedocument.spreadsheetml.sheet

  1. 文本格式(限制txt)

txt:text/plain

  1. 文件格式(限制zip和rar)

zip:application/zip
rar:application/x-rar-compressed

组件封装

提示:这里用来判断是否包含限制类型、文件大小是否符合标准

<template>
  <van-uploader
    ref="uploaderRef"
    :before-read="beforeRead"
    :accept="acceptType"
    :max-size="maxSize"
    :max-count="maxCount"
    preview-size="55px"
  >
    <span class="text">{{
      text
    }}</span>
  </van-uploader>
</template>

<script lang="ts" setup>
import { Notify, Toast } from 'vant'
import fileApi from '~/api/file'
const uploaderRef = ref() // 文件实例
interface uploadProps {
  acceptType?: string // 接受类型
  limit?: number // 限制文件个数
  maxSize?: number // 文件大小限制
  text?: string
  fileExtension?: string // 文件后缀名
  imgExtension?: string // 图片后缀名
  maxCount?: number
}

interface fileItem {
  fileName: string
  fileUrl: string
  fileType: string
  size: number
  isImage?: boolean
  id?: string
  businessId?: string
  createTime?: string
  unit?: string
}

const emits = defineEmits(['success', 'delete',])
const props = withDefaults(defineProps<uploadProps>(), {
  text: '上传附件',
  limit: 10,
  maxSize: 200,
  maxCount: 99,
  acceptType:
    'image/jpeg, image/jpg, image/png, text/plain, application/msword, application/vnd.openxmlformats-officedocument.wordprocessingml.document, application/vnd.ms-excel, application/vnd.openxmlformats-officedocument.spreadsheetml.sheet, application/vnd.ms-powerpoint, application/vnd.openxmlformats-officedocument.presentationml.presentation ,application/pdf',
  fileExtension: 'pdf, txt, doc, docx, xls, xlsx, ppt, pptx',
  imgExtension: 'jpeg/jpg/png',
  fileList: () => [],
  showUploadBtn: true,
  type: 'add',
})

// 获得文件后缀名
const getFileExtension = (name: string) => {
  const extension = name.substring(name.lastIndexOf('.') + 1).toLowerCase() // 文件后缀
  return extension
}

// 文件上传钩子
const beforeRead = (file: any) => {
  const extension = file.name
    .substring(file.name.lastIndexOf('.') + 1)
    .toLowerCase() // 文件后缀
    
  // 判断是否图片类型
  const isImage = props.imgExtension.includes(extension)
  // 判断是否超过最大上传限制,当前限制了200m
  const isMax = file.size / 1024 / 1024 < props.maxSize
  if (!isMax) {
    Notify({
      type: 'danger',
      message: `文件大小上限为${props.maxSize}M`,
      duration: 1000,
    })
    return false
  }
  // 限制上传类型
  const isLimit = props.fileExtension.includes(extension) || props.imgExtension.includes(extension)
  if (!isLimit) {
    Notify({
      type: 'danger',
      message: `文件上传格式不正确`,
      duration: 1000,
    })
    return false
  }
  // 通过校验后执行上传文件方法
  uploadFile(file)
  return true
}

// 唤醒上传文件功能
const openUploader = () => {
  uploaderRef.value.chooseFile()
}

const deleteList = (index: number) => {
  emits('delete', index)
}

// 上传文件
const uploadFile = async (file: File) => {
  Toast.loading({
    duration: 0,
    message: '上传中...',
    forbidClick: true,
  })
  const formData = new FormData()
  formData.append('file', file)
  formData.append('transfer', '0')
  const { code, data } = await fileApi.uploadFile(formData) // 这里替换成实际项目中的api名称
  const extension = file.name
    .substring(file.name.lastIndexOf('.') + 1)
    .toLowerCase() // 文件后缀
  const isImage = props.imgExtension.includes(extension)
  if (code.value === 0) {
    const fileData = {
      fileName: file.name,
      fileUrl: data.value.message, // 图片回显
      size: file.size,
      fileType: getFileExtension(file.name),
      isImage,
      unit: 'KB',
    }
    // 抛出成功信息
    emits('success', fileData)
    Notify({
      type: 'success',
      message: `上传成功`,
      duration: 1000,
    })
    Toast.clear()
    return true
  } else {
    Notify({
      type: 'danger',
      message: `上传失败`,
      duration: 1000,
    })
    Toast.clear()
  }
}

defineExpose({
  openUploader,
})
</script>
<style lang="less" scoped>
.text {
  color: #86909c;
  font-size: 15px;
  display: inline-block;
}
</style>

小结

本文参考来源
上传附件类型统计(accept)日常word、pdf、ppt、excel等

input的type=file上传文件accept中限制文件类型pdf、doc、docx、 jpg、 png、xls 、xlsx等格式

input的file类型指定上传类型

html <input type=file>上传文件时,accept属性值汇总,支持文件格式,限制文件格式,限制上传图片的格式

  • 3
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 14
    评论
Vue Vant-UI是Vue.js的一个移动端UI组件库,是一个轻量级的、高效的组件库,非常适合用于移动端前端开发。其Van-UploaderVant-UI的上传文件组件,允许用户将文件上传到服务器或第三方存储库。 在实现头像图片上传时,我们可以采用如下步骤: 1. 首先需要安装Vant-UI组件库。可以通过npm命令进行安装,输入如下代码:npm install vant --save 2. 在Vue项目引入Vant-UI组件库。在main.js文件写入如下代码:import Vant from 'vant' import 'vant/lib/vant-css/index.css' Vue.use(Vant) 3. 在需要使用上传头像的组件引入Van-Uploader组件,并编写如下代码: <template> <van-uploader :show-upload="false" :before-read="beforeRead" :after-read="afterRead" > <van-icon name="photograph" /> </van-uploader> </template> <script> export default { data() { return { file: '' } }, methods: { beforeRead(file) { if (file.type !== 'image/jpeg' && file.type !== 'image/png') { this.$toast('请上传 JPG/PNG 格式的图片'); return false; } if (file.size > 500 * 1024) { this.$toast('图片大小不能超过 500KB'); return false; } }, afterRead(file) { this.file = URL.createObjectURL(file.file); } } } </script> 4. 上面的代码,我们主要使用Van-Uploader组件的before-read和after-read两个事件回调函数。before-read为上传文件之前的校验函数,例如判断文件类型和文件大小是否符合要求,这里我们限制了文件类型为JPG/PNG并且大小不能超过500KB。after-read则表示读取文件后的回调函数,我们将上传的文件读取为本地链接并保存到file属性,以便进行后续处理。 5. 最后,将file属性传递给后端进行处理,例如将该链接保存到服务器或者上传到第三方存储库。 总之,使用Van-Uploader组件可以轻松实现头像图片上传功能,同时也可以根据需求进行个性化的定制和扩展,是一个非常实用且易于使用的组件。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 14
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

kk楷楷

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值