# Uploader 文件上传

# 引入

import PressUploader from 'press-ui/press-uploader/press-uploader';

export default {
  components: {
    PressUploader,
  }
}

# 代码演示

# 基础用法

通过 fileList参数(对象数组),显示预置的图片。其中元素的url属性为图片路径。

 <PressUploader
  :file-list="fileList1"
  name="1"
  multiple
  :max-count="10"
  @afterRead="afterRead"
  @delete="deletePic"
/>
export default {
  data() {
    return {
      fileList1: [],
    }
  },
  methods:{
    // 删除图片
    deletePic(event) {
      this[`fileList${event.name}`].splice(event.index, 1)
    },
    // 新增图片
    async afterRead(event) {
      // 当设置 multiple 为 true 时, file 为数组格式,否则为对象格式
      let lists = [].concat(event.file)
      let fileListLen = this[`fileList${event.name}`].length
      lists.map((item) => {
        this[`fileList${event.name}`].push({
          ...item,
          status: 'uploading',
          message: '上传中'
        })
      })
      for (let i = 0; i < lists.length; i++) {
        const result = await this.uploadFilePromise(lists[i].url)
        let item = this[`fileList${event.name}`][fileListLen]
        this[`fileList${event.name}`].splice(fileListLen, 1, Object.assign(item, {
          status: 'success',
          message: '',
          url: result
        }))
        fileListLen += 1
      }
    },
    uploadFilePromise(url) {
      return new Promise((resolve, reject) => {
        let a = uni.uploadFile({
          url: 'https://xxxx/upload',
          filePath: url,
          name: 'file',
          formData: {
            user: 'test'
          },
          success: (res) => {
            setTimeout(() => {
              resolve(res.data.data)
            }, 1000)
          }
        });
      })
    },
  }
}

# 上传视频

设置acceptvideo,即为上传视频。

<PressUploader
  :file-list="fileList2"
  name="2"
  multiple
  :max-count="10"
  accept="video"
  @afterRead="afterRead"
  @delete="deletePic"
/>

# 上传状态

通过 status 属性可以标识上传状态,uploading 表示上传中,failed 表示上传失败,done 表示上传完成。

<PressUploader
  :file-list="fileListStatus"
  name="2"
  multiple
  :max-count="10"
  accept="video"
  @afterRead="afterRead"
  @delete="deletePic"
/>
export default {
  data() {
    return {
      fileListStatus: [
        {
          url: IMG_URL,
          status: 'uploading',
          message: '上传中...',
        }, 
        {
          url: IMG_URL,
          status: 'failed',
          message: '上传失败',
        },
      ],
    }
  }
}

# 文件预览

设置 previewFullImagetrue,即可预览文件。

<PressUploader
  :file-list="fileList3"
  name="3"
  multiple
  :max-count="10"
  :preview-full-image="true"
  @afterRead="afterRead"
  @delete="deletePic"
/>

# 限制上传数量

通过 maxCount 限制上传数量,并隐藏上传按钮。

<PressUploader
  :file-list="fileList4"
  name="4"
  multiple
  :max-count="2"
  @afterRead="afterRead"
  @delete="deletePic"
/>

# 限制上传大小

通过 max-size 属性可以限制上传文件的大小,超过大小的文件会被自动过滤,这些文件信息可以通过 oversize 事件获取。

<PressUploader multiple :max-size="500 * 1024" @oversize="onOversize" />
export default {
  methods: {
    onOversize(file) {
      console.log(file);
      Toast('文件大小不能超过 500kb');
    },
  },
};

# 自定义上传样式

通过默认插槽,可以自定义上传样式。

<PressUploader
  :file-list="fileList6"
  name="6"
  multiple
  :max-count="1"
  width="250"
  height="150"
  @afterRead="afterRead"
  @delete="deletePic"
>
  <image
    src="https://mike-1255355338.cos.ap-guangzhou.myqcloud.com/article/2023/10/own_mike_799718017ac81b11c0.png"
    mode="widthFix"
    style="width: 250px;height: 150px;"
  />
</PressUploader>

# 上传前置处理

通过传入 beforeRead 函数可以在上传前进行校验和处理,返回 true 表示校验通过,返回 false 表示校验失败。支持返回 Promisefile 对象进行自定义处理,例如压缩图片。

<PressUploader :before-read="beforeRead" />
export default {
  methods: {
    // 返回布尔值
    beforeRead(file) {
      if (file.type !== 'image/jpeg') {
        Toast('请上传 jpg 格式图片');
        return false;
      }
      return true;
    },
    // 返回 Promise
    asyncBeforeRead(file) {
      return new Promise((resolve, reject) => {
        if (file.type !== 'image/jpeg') {
          Toast('请上传 jpg 格式图片');
          reject();
        } else {
          let img = new File(['foo'], 'bar.jpg', {
            type: 'image/jpeg',
          });
          resolve(img);
        }
      });
    },
  },
};

# 禁用文件上传

通过 disabled 属性禁用文件上传。

<PressUploader disabled />

# API

# Props

参数 说明 类型 默认值
accept 接受的文件类型, 可选值为 all, media, image, file, video string image
capture 图片或视频拾取模式,当acceptimage时设置capture,可选额外camera可以直接调起摄像头 string | array ['album', 'camera']
compressed acceptvideo时生效,是否压缩视频 boolean true
camera acceptvideo时生效,可选值为back, front string back
max-duration acceptvideo时生效,拍摄视频最长拍摄时间,单位s number 60
upload-icon 上传区域的图标,只能内置图标 string photograph
upload-icon-color 上传区域的图标的颜色 string #d3d4d6
preview-full-image 是否显示组件自带的图片预览功能 boolean true
max-count 最大上传数量 number 52
disabled 是否禁用用 string image
image-mode 预览上传的图片时的裁剪模式,和image组件mode属性一致 string aspectFill
name 标识符,可以在回调函数的第二项参数中获取 string file
size-type 所选的图片的尺寸, 可选值为 original, compressed array ['original', 'compressed']
multiple 是否开启图片多选,部分安卓机型不支持 boolean false
deletable 是否展示删除按钮 boolean true
max-size 文件大小限制,单位为byte number Number.MAX_VALUE
file-list 显示已上传的文件列表 array -
upload-text 上传区域的提示文字 string -
width 内部预览图片区域和选择图片按钮的区域宽度 number 80
height 内部预览图片区域和选择图片按钮的区域高度 number 80
preview-image 是否在上传完成后展示预览图 boolean true
use-before-read 是否开启文件读取前事件 boolean false
before-read 读取前的处理函数 function -
after-read 读取后的处理函数 function -
custom-style 自定义样式 string -

# Methods

事件名 说明
afterRead 读取后的处理函数
beforeRead 读取前的处理函数

# Events

事件名 说明 参数
afterRead 读取后的处理函数 {file, lists, name}
beforeRead 读取前的处理函数 {file, lists, name}
oversize 图片大小超出最大允许大小 {file, lists, name}
clickPreview 全屏预览图片时触发 {url, lists, name}
delete 删除图片 {file,index, name}
error 选择文件出错 error
chooseFile 点击选择文件 disabled

# Slot

名称 说明
default 自定义上传样式

# 在线调试

# 常见问题

# H5 上传

uni-app 在 H5 端,实现了 chooseImagechooseVideo 等方法,核心是动态创建 input 标签,监听其 change 事件,并主动触发其点击事件。

Press UI 在非 uni-app 环境也按照这个方法实现了一遍,从而兼容普通 Vue 项目。

# 文件对象

一个文件对象的属性包括:

  • lastModified
  • lastModifiedDate
  • name
  • size
  • type
  • webkitRelativePath (in chrome)
横屏