Vue3 использует van-uploader для обнаружения некоторых моделей Android (Xiaomi, vivo, oppo и т. д.), которые не могут загружать файлы.

обзор

Недавно при работе на мобильном терминале я столкнулся с необходимостью загрузки вложений, а именно, что можно загружать только следующие типы файлов:

  • Файлы изображений (jpeg, jpg, png)
  • Файлы документации (pdf, txt, doc, docx, xls, xlsx, ppt, pptx)

Здесь я использую компонент загрузки Youzan, но после выхода в Интернет я обнаружил, что с телефонами Apple проблем нет, но есть проблемы с некоторыми телефонами Android.После нескольких изменений и корректировок ограниченных типов файлов загрузка проходит нормально! ! ! Поздравляю, я записал решение таким образом, надеясь всем помочь.

Соответствующий формат вложения

  1. Формат изображения (лимит png, jpeg, png)

accept=“изображение/jpeg,изображение/png,изображение/jpg”
jpeg: изображение/jpeg
png: изображение/png
jpg: изображение/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: текст/обычный

Упаковка компонентов

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

<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>

краткое содержание

Эта статья относится к источникам
для загрузки статистики типа вложений (принять) ежедневно word, pdf, ppt, excel и т. д.

тип ввода=файл загрузить файл принять ограничение типа файла pdf, doc, docx, jpg, png, xls, xlsx и другие форматы

Тип файла ввода определяет тип загрузки

html <input type=file> При загрузке файлов сводка значения атрибута принимается, поддерживает формат файла, ограничивает формат файла, ограничивает формат загружаемых изображений

おすすめ

転載: blog.csdn.net/weixin_45331887/article/details/131551216