Dropzone 图片上传插件
Dropzone 是一个开源的 JavaScript 库,提供文件的异步上传功能,并支持拖拽上传功能
页面引用
CSS 部分,其中 basic.min.css
提供了官网的炫酷上传效果
1 | <link rel="stylesheet" href="/static/assets/plugins/dropzone/min/dropzone.min.css" /> |
JS 部分
1 | <script src="/static/assets/plugins/dropzone/min/dropzone.min.js"></script> |
启用 Dropzone
只需要一个 div
元素,用 JavaScript 代码启用即可
HTML 结构如下:
1 | <div id="dropz" class="dropzone"></div> |
JavaScript 启用代码如下:
1 | var myDropzone = new Dropzone("#dropz", { |
其中 url
是必须的值,指明文件上传提交到哪个页面。其他的值都是可选的,如果使用默认值的话可以省略。
配置 Dropzone
此插件的特色就在于非常灵活,提供了许多可选项、事件等。下面分类介绍常用的配置项。
功能选项
url
:最重要的参数,指明了文件提交到哪个页面method
:默认为post
,如果需要,可以改为put
paramName
:相当于<input>
元素的name
属性,默认为file
maxFilesize
:最大文件大小,单位是 MBmaxFiles
:默认为 null,可以指定为一个数值,限制最多文件数量addRemoveLinks
:默认 false。如果设为 true,则会给文件添加一个删除链接acceptedFiles
:指明允许上传的文件类型,格式是逗号分隔的 MIME type 或者扩展名。例如:image/*, application/pdf, .psd, .obj
uploadMultiple
:指明是否允许 Dropzone 一次提交多个文件。默认为 false。如果设为 true,则相当于 HTML 表单添加 multiple 属性headers
:如果设定,则会作为额外的 header 信息发送到服务器。例如:{"custom-header": "value"}
init
:一个函数,在 Dropzone 初始化的时候调用,可以用来添加自己的事件监听器forceFallback
:Fallback 是一种机制,当浏览器不支持此插件时,提供一个备选方案。默认为 false。如果设为 true,则强制 fallbackfallback
:一个函数,如果浏览器不支持此插件则调用
翻译选项
dictDefaultMessage
:没有任何文件被添加的时候的提示文本dictFallbackMessage
:Fallback 情况下的提示文本dictInvalidInputType
:文件类型被拒绝时的提示文本dictFileTooBig
:文件大小过大时的提示文本dictCancelUpload
:取消上传链接的文本dictCancelUploadConfirmation
:取消上传确认信息的文本dictRemoveFile
:移除文件链接的文本dictMaxFilesExceeded
:超过最大文件数量的提示文本
常用事件
以下事件接收 FILE
为第一个参数
addedfile
:添加了一个文件时发生removedfile
:一个文件被移除时发生。你可以监听这个事件并手动从服务器删除这个文件uploadprogress
:上传时按一定间隔发生这个事件。第二个参数为一个整数,表示进度,从 0 到 100。第三个参数是一个整数,表示发送到服务器的字节数。当一个上传结束时,Dropzone 保证会把进度设为 100。注意:这个函数可能被以同一个进度调用多次success
:文件成功上传之后发生,第二个参数为服务器响应complete
:当文件上传成功或失败之后发生canceled
:当文件在上传时被取消的时候发生maxfilesreached
:当文件数量达到最大时发生maxfilesexceeded
:当文件数量超过限制时发生
以下事件接收一个 FILE LIST
作为第一个参数(仅当 UPLOADMULTIPLE
被设为 TRUE
时才会发生)
successmultiple
completemultiple
cancelmultiple
特殊事件
totaluploadprogress
:第一个参数为总上传进度,第二个参数为总字节数,第三个参数为总上传字节数。
使用案例
1 | var myDropzone = new Dropzone("#dropz", { |
服务端支持
前端工作做完后,后台需要提供文件上传支持,我们使用 Spring MVC 来接收上传的文件
POM
Spring MVC 上传文件需要 commons-fileupload:commons-fileupload
依赖支持,pom.xml
文件如下:
1 | <dependency> |
配置 spring-mvc.xml
需要 Spring 注入 multipartResolver
实例,spring-mvc.xml
增加如下配置:
1 | <!-- 上传文件拦截,设置最大上传文件大小 10M = 10*1024*1024(B) = 10485760 bytes --> |
控制器关键代码
以下为控制器中接收文件的关键代码:
1 | package com.funtl.my.shop.web.admin.web.controller; |