docs_vue2/one/docs/components/uploader.md
2021-10-18 16:51:48 +08:00

14 KiB
Raw Blame History

Uploader 上传

示例

文件上传

设置 type 的值为 file 进入文件上传模式。

图片上传

设置 type 的值为 image 进入图片上传模式。

媒体上传

设置 type 的值为 media 进入媒体上传模式。

前端校验

图片格式、大小、数量校验以及使用 validator 自定义校验。

自定义配置

使用 upload 自定义上传过程,使用 controls 配置浮层操作项。

API

属性

属性 类型 默认值 描述
ui string= - [^ui]
type string 'file' [^type]
value `Object Array -
key-field string 'key' 用于指定文件对象的唯一 key作为数据变化时正确处理文件列表顺序的依据。
name string 'file' 原生 <input> 元素的 name
action string - 上传地址。
headers Object uploader.headers 需要加入 HTTP 请求头 的内容。可进行全局统一配置。
with-credentials boolean true XMLHttpRequestwith-credentials 属性。
request-mode string uploader.requestMode [^request-mode]
iframe-mode string uploader.iframeMode [^iframe-mode]
callback-namespace string uploader.callbackNamespace request-mode 的值为 'iframe' 并且 iframe-mode 的值为 'callback' 的模式下,指定回调函数的命名空间,放在 window 对象下。可进行全局统一配置。
data-type string 'json' [^data-type]
convert-response uploader.convertResponse - [^convert-response]
accept string - 与原生 <input> 元素 的 accept 相同,在浏览器的文件类型筛选后再加一层校验。对于类似 application/msword 这样的 MIME type 与扩展名对不上的情形跳过校验。
max-count number - 最大文件数量。
max-size `number string` -
validator `function(Object): Object Promise -
payload Object - 附带在上传请求中的额外参数。
autoupload boolean true 指定是否在选完文件后立刻上传。
order string 'asc' [^order]
picker-position string 'after' [^picker-position]
upload function(Object, Object): function - [^upload]
controls function(Object, Array<Object>): Array<Object> - [^controls]
multiple boolean false 上传多个文件,当 max-count1multipletrue,那么 value 也是数组。
entries function(Array<Object>): Array<Object> - [^entries]
after-pick function(Array<Object>): void - 选择文件之后的回调。
sortable boolean false 文件列表是否可以排序。
preview-options object {wrap: true, indicator: 'number'} 传递给 Lightbox 的预览选项

^^^ui 预设样式。

+++枚举值

描述
s 小尺寸样式。
m 中尺寸样式。
+++
^^^

^^^type 上传类型。

+++枚举值

描述
file 文件上传。
image 图片上传。
media 媒体上传(支持视频和图片)。
video 视频上传。
+++
^^^

^^^value 当 multipletrue,返回文件对象的数组。另外,当 max-count 被设置为大于 1 的值,则会视为开启了 multiple

每个文件对象的类型为 {name: string, src: string, ...},以及在 convert-response 中自定义添加的字段。 ^^^

^^^request-mode 指定异步上传方式。可进行全局统一配置。

+++枚举值

描述
xhr 通过 XMLHttpRequest 上传。
iframe 通过 <iframe> 上传。
custom 自定义上传过程,通过 prop upload 方法上传。
+++
^^^

^^^iframe-mode 指定在 request-mode 的值为 iframe 的模式下,上传成功后的回调方式。可进行全局统一配置。

+++枚举值

描述
postmessage 通过 PostMessage 回调。
callback 通过调用 windowcallback-namespace 里的回调函数回调。
+++
^^^

^^^data-type 如果回调的值是文本, 指明文本的解析方式。如果回调的数据是 Object,则 data-type 可以为空。

+++枚举值

描述
json 回调的文本是 JSON。
text 回调的文本是普通文本。
+++
^^^

^^^convert-response 将回调数据转换成需要的格式的函数,使组件能够判断上传是否成功以便显示相应结果,参数是回调数据。返回结果的格式要求如下:

+++字段详情

字段 类型 描述
success boolean 表示上传是否成功。
name string= 文件的名称。successtrue 时必须。
src string= 文件的地址。successtrue 时必须。
message string= 上传失败时的出错信息。successfalse 时必须。

还可以给返回结果加上其它自定义的属性,这些自定义属性会被包含在 value 以及 changesuccessfailureremoveprogress 事件的回调参数 file 中 。可进行全局统一配置。 +++ ^^^

^^^order 上传文件的显示顺序,按照开始上传的时间排序。

+++枚举值

描述
asc 升序排列。
desc 降序排列。
+++
^^^

^^^picker-position 图片上传模式下,上传按钮在图片队列中的位置。

+++枚举值

描述
before 上传按钮始终在队列最前面。
after 上传按钮始终在队列最后面。
+++
^^^

^^^validator 自定义校验逻辑,参数为原生 File 对象。返回结果的格式要求如下:

+++字段详情

字段 类型 描述
valid boolean 是否通过校验。
message string= validfalse 时的错误提示信息。

支持异步校验,返回值可以是一个 resolve 上述返回结果的 Promise

^^^

^^^upload 在 request-mode 的值是 'custom' 的情况下自定义上传过程,第一个参数为原生 File 对象,第二个参数为包含与上传过程相关的回调函数的对象,具体字段如下:

+++字段详情

字段 类型 描述
onload function 上传完成的回调函数,参数内容与 convert-response prop 返回值相同。
onprogress function 上传进度发生变化的回调函数,参数为 { loaded: number, total: number }loaded 为已上传部分字节数,total 为文件总字节数。
oncancel function 自定义上传主动取消时对组件进行的回调,无参数。
onerror function 上传出错的回调函数,参数为 { message: string }message 为错误提示信息。

如果 upload 返回一个函数,该函数将在用户操作取消或上传组件销毁时被调用,用来中断自定义上传过程。 ^^^

^^^controls 图片上传模式下,用来自定义配置图片遮罩浮层上的操作项,参数为 (file: Object, defaultControls: Array<Object>)file 为文件相关信息,defaultControls 为包含默认的操作项的数组。可根据文件状态的不同,返回包含不同的操作项的数组。每个操作项的具体字段如下:

+++字段详情

字段 类型 描述
name string 操作项的名称,点击该按钮后会抛出同名的事件,事件的回调参数为 (file: Object, index: number) file 为触发事件的文件对象,index 为文件在列表中的序号。
label string 操作项的文字描述。
icon string 操作项使用的图标。
disabled boolean= 操作项是否被禁用。如果该字段为空,则该操作项的禁用状态跟随组件整体的禁用状态。
^^^

^^^entries 控制每个上传文件的操作项,如删除,预览等,会传递默认的操作项数组作为参数,返回实际生效的操作项数组。操作项对象参考 controls 属性的字段详情。 ^^^

插槽

名称 描述
button-label [^button-label]
upload 图片上传模式下,上传按钮的区域。
desc 对文件数量、格式、大小等的提示内容。
file [^file]
file-before 单个文件内容之前的区域。作用域参数与 file 插槽相同。
file-after 单个文件内容之后的区域。作用域参数与 file 插槽相同。
uploading 图片上传模式下,上传中的单个图片的区域。作用域参数与 file 插槽相同。
failure 图片上传模式下,上传失败的单个图片的区域。作用域参数与 file 插槽相同。

^^^button-label 上传按钮里的内容。

默认内容:文件上传为提示选择文件,图片上传则为上传图片图标。 ^^^

^^^file 单个文件的区域,用来定制文件内容。

+++作用域参数

名称 类型 描述
name string 文件的名称。
src string 文件的地址。
status string 文件的状态。'success' 表示上传成功;'uploading' 表示正在上传;'failure' 表示上传失败。
index number 文件在列表中的序号。
+++
^^^

事件

名称 描述
change [^event-change]
remove [^event-remove]
success 上传成功时触发,回调参数与 remove 事件的回调参数相同。
failure 上传失败时触发,回调参数与 remove 事件的回调参数相同。
invalid [^event-invalid]
statuschange [^event-statuschange]
progress [^event-progress]

^^^event-change 只在上传成功、删除文件时触发,回调参数为 (value)

+++参数详情

名称 类型 描述
value `Object Array
+++
^^^

^^^event-remove 删除文件时触发,回调参数为 (file, index)

+++参数详情

名称 类型 描述
file Object 被删除的文件。
index number 被删除的文件的序号。

file 字段详情

字段 类型 描述
name string 文件名称。
src string 文件地址。
status string 上传状态。'success' 表示上传成功;'uploading' 表示正在上传;'failure' 表示上传失败。

同时也包含在 convert-response 中添加的自定义属性。 +++ ^^^

^^^event-invalid 文件校验失败时触发,回调参数为 (validity: Object)

+++参数字段详情

名称 类型 描述
file Object 没有通过校验的文件信息,与 remove 事件的回调参数中的 file 相同。如果校验失败的原因是选择的文件数量超过最大数量 max-count 限制,则这个字段为空。
errors Array<Object> 包含该文件所有校验错误信息的数组,数组的每一项是包含校验失败信息的对象。
+++

+++校验失败信息字段详情

名称 类型 描述
type string 校验失败的类型,类型枚举值可从 Uploader.errors 对象获取,如 Uploader.errors.SIZE_INVALID
value `number string
message string 检验失败的提示信息。
+++

+++校验失败类型与参数关系

类型 描述 value 类型 value 描述
TYPE_INVALID 文件类型校验失败。 string 文件名称。
SIZE_INVALID 文件大小校验失败。 number 文件大小字节数。
TOO_MANY_FILES 选择的文件数超过 max-count 限制。 number 已选择的文件数。
CUSTOM_INVALID validator 自定义校验失败。 Object 文件对象,字段同 remove 事件回调参数。
+++
^^^

^^^event-statuschange 在所有文件总的状态发生变化时触发,回调参数为组件整体的状态 (status: string)

+++值详情

描述
empty 没有选择任何文件上传。
uploading 有任一文件正在上传中。
failure 有任一文件上传失败。
success 所有文件上传成功。
+++
^^^

^^^event-progress 在 request-mode 的值为 'xhr' 的情况下,在上传进度发生变化时触发,回调参数为 (file, index, event)

+++参数详情

名称 类型 描述
file Object remove 事件的回调参数中的 file 相同。
index number 正在上传的文件的序号。
event Event 上传进度原生事件。
+++
^^^

全局配置

名称 类型 默认值 描述
uploader.requestMode string 'xhr' 参见 request-mode 属性。
uploader.iframeMode string 'postmessage' 参见 iframe-mode 属性。
uploader.callbackNamespace string 'veuiUploadResult' 参见 callback-namespace 属性。
uploader.headers Object - 参见 headers 属性。
uploader.convertResponse function(Object): Object - 参见 convert-response 属性。
uploader.pickerPosition string 'after' 参见 picker-position 属性。

图标

名称 描述
upload 上传文件。
add-image 上传图片。
clear 删除。
success 上传成功。
failure 上传失败。
loading 上传中。
file 已上传文件。
alert 校验失败警告。
preview 预览图片。