怎么使用bootstrap-fileinput实现文件上传
这篇文章主要介绍怎么使用bootstrap-fileinput实现文件上传,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!
一、准备
1、首先需要准备我们的插件,下载地址如下:
https://github.com/kartik-v/bootstrap-fileinput/
在文件中:
js:插件核心js代码,我们需要引用fileinput.min.js/fileinput.js
即可,默认插件语言为英文,如需要中文需要引用js/locales/zh.js
(其他语言引用相应的js文件) 。
js/plugins:相关辅助插件,piexif.min.js
(resize image插件)、sortable.js
(初始化预览窗口缩略图排序插件)、purify.js
(看说明是净化html代码用的,试了下没有搞明白具体有说明作用)。
css:插件核心css代码,fileinput.min.css/fileinput.css
(核心css代码,引用任何一个)、fileinput-rtl.min.css/fileinput-rtl.css
(选用这组css,文件选择框会和从右向左排列,即选择文件等相关按钮按钮在左边,文件框在右边)。
themes:主题,如需要插件主题样式可引用主题文件夹下的相应js
和css
文件。
我们除了上面介绍的内容外,我们还可以打开压缩包中的example/index.html
或者访问http://plugins.krajee.com/file-basic-usage-demo
来进行查看示例;还可以根据示例的代码选择需要的控件代码使用。
2、代码引用
我们在进编程的时候是需要引用 jquery,而且还需要结合 bootstrap 使用,即页面需要引入bootstrap 相关 js 和 css 文件;不仅这样我们还需要引用到相关的fileinput.js
和css
,在中文中则需要引用js/locales/zh.js
;如果有时候需要主题样式时则要引用themes下相关文件夹中的 js 和 css。
二、使用示例
1、基本用法,通过自动将一个普通的 input
框渲染成高大上的文件上传选择框,代码如下:
我们只需要将 class 设置为 file 即可
2、隐藏文件预览窗口
当我们设置属性:data-show-preview="false"
之后就等同于初始化属性:showPreview:false
3、使用 input 属性和 data-** 属性创建多样化的文件上传框
下面是使用相关内容的代码:
三、option选项说明
属性名 | 属性类型 | 描述说明 | 默认值 |
language | String | 多语言设置,使用时需提前引入\locales文件夹下对应的语言文件, 中文zh,引入语言文件必须放在fileinput.js之后 | 'en' |
showCaption | Boolean | 是否显示被选文件的简介 | true |
showBrowse | Boolean | 是否显示浏览按钮 | true |
showPreview | Boolean | 是否显示预览区域 | true |
showRemove | Boolean | 是否显示移除按钮 | true, |
showUpload | Boolean | 是否显示上传按钮 | true, |
showCancel | Boolean | 是否显示取消按钮 | true, |
showClose: | Boolean | 是否显示关闭按钮 | true |
showUploadedThumbs | Boolean | true | |
browseOnZoneClick | Boolean | false | |
autoReplace | Boolean | 是否自动替换当前图片,设置为true时,再次选择文件, 会将当前的文件替换掉。 | false |
generateFileId | Object | null | |
previewClass | String | 添加预览按钮的类属性 | '' |
captionClass | String | '' | |
frameClass | String | 'krajee-default' | |
mainClass | String | 'file-caption-main' | |
mainTemplate | Object | null | |
purifyHtml | Boolean | true | |
fileSizeGetter | Object | null | |
initialCaption | String | '' | |
initialPreview | Array/Object | [] | |
initialPreviewDelimiter | String | '*$$*' | |
initialPreviewAsData | Boolean | false | |
initialPreviewFileType | String | 'image' | |
initialPreviewConfig | Array/Object | [] | |
initialPreviewThumbTags | Array/Object | [] | |
previewThumbTags | Object | {} | |
initialPreviewShowDelete | Boolean | true | |
removeFromPreviewOnError | Boolean | false | |
deleteUrl | String | 删除图片时的请求路径 | '' |
deleteExtraData | Object | 删除图片时额外传入的参数 | {} |
overwriteInitial | Boolean | true | |
previewZoomButtonIcons | Object | { prev: '', next: '', toggleheader: '', fullscreen: '', borderless: '', close: '' }, | |
previewZoomButtonClasses | Object | { prev: 'btn btn-navigate', next: 'btn btn-navigate', toggleheader: 'btn btn-default btn-header-toggle', fullscreen: 'btn btn-default', borderless: 'btn btn-default', close: 'btn btn-default' }, | |
preferIconicPreview | Boolrean | false | |
preferIconicZoomPreview | Boolrean | false | |
allowedPreviewTypes | undefined | undefined | |
allowedPreviewMimeTypes | Object | null | |
allowedFileTypes | Object | 接收的文件后缀,如['jpg', 'gif', 'png'],不填将不限制上传文件后缀类型 | null |
allowedFileExtensions | Object | null | |
defaultPreviewContent | Object | null | |
customLayoutTags | Object | {} | |
customPreviewTags | Object | {} | |
previewFileIcon | String | '' | |
previewFileIconClass | String | 'file-other-icon' | |
previewFileIconSettings | Object | {} | |
previewFileExtSettings | Object | {} | |
buttonLabelClass | String | 'hidden-xs' | |
browseIcon | String | ' ' | |
browseClass | String | 'btn btn-primary' | |
removeIcon | String | '' | |
removeClass | String | 'btn btn-default' | |
cancelIcon | String | '' | |
cancelClass | String | 'btn btn-default' | |
uploadIcon | String | '' | |
uploadClass | String | 'btn btn-default' | |
uploadUrl | String | 上传文件路径 | null |
uploadAsync | boolean | 是否为异步上传 | true |
uploadExtraData | 上传文件时额外传递的参数设置 | {} | |
zoomModalHeight | number | 480 | |
minImageWidth | String | 图片的最小宽度 | null |
minImageHeight | String | 图片的最小高度 | null |
maxImageWidth | String | 图片的最大宽度 | null |
maxImageHeight | String | 图片的最大高度 | null |
resizeImage | boolean | false | |
resizePreference | String | 'width' | |
resizeQuality | number | 0.92 | |
resizeDefaultImageType | String | 'image/jpeg' | |
minFileSize | number | 单位为kb,上传文件的最小大小值 | 0 |
maxFileSize | number | 单位为kb,如果为0表示不限制文件大小 | 0 |
resizeDefaultImageType | number | 25600(25MB) | |
minFileCount | number | 表示同时最小上传的文件个数 | 0 |
maxFileCount | number | 表示允许同时上传的最大文件个数 | 0 |
validateInitialCount | boolean | false | |
msgValidationErrorClass | String | 'text-danger' | |
msgValidationErrorIcon | String | ' ' | |
msgErrorClass | String | 'file-error-message' | |
progressThumbClass | String | "progress-bar progress-bar-success progress-bar-striped active" | |
rogressClass | String | "progress-bar progress-bar-success progress-bar-striped active" | |
progressCompleteClass | String | "progress-bar progress-bar-success" | |
progressErrorClass | String | "progress-bar progress-bar-danger" | |
progressUploadThreshold | number | 99 | |
previewFileType | String | 预览文件类型,内置['image', 'html', 'text', 'video', 'audio', 'flash', 'object','other']等格式 | 'image' |
elCaptionContainer | String | null | |
elCaptionText | String | 设置标题栏提示信息 | null |
elPreviewContainer | String | null | |
elPreviewImage | String | null | |
elPreviewStatus | String | null | |
elErrorContainer | String | null | |
errorCloseButton | String | '×' | |
slugCallback | String | 暂时没有搜到说明,调试显示,在文件选择后会调到这个方法。 | null |
dropZoneEnabled | boolean | 是否显示拖拽区域 | true |
dropZoneTitleClass | String | 拖拽区域类属性设置 | 'file-drop-zone-title' |
fileActionSettings | Object | {} | |
otherActionButtons | String | '' | |
textEncoding | String | 编码设置 | 'UTF-8' |
ajaxSettings | Object | {} | |
ajaxDeleteSettings | Object | {} | |
showAjaxErrorDetails | boolean | true |
四、Method说明
方法名 | 参数 | 描述 |
fileerror | 异步上传错误结果处理 $('#uploadfile').on('fileerror', function(event, data, msg) { }); | |
fileuploaded | 异步上传成功结果处理 $("#uploadfile").on("fileuploaded", function (event, data, previewId, index) { }) | |
filebatchuploaderror | 同步上传错误结果处理 $('#uploadfile').on('filebatchuploaderror', function(event, data, msg) { }); | |
filebatchuploadsuccess | 同步上传成功结果处理 $('#uploadfile').on('filepreupload', function(event, data, previewId, index) { }); | |
filebatchselected | 选择文件后处理事件 $("#fileinput").on("filebatchselected", function(event, files) { }); | |
upload | 文件上传方法 $("#fileinput").fileinput("upload"); | |
fileuploaded | 上传成功后处理方法 $("#fileinput").
| |
filereset | ||
fileclear | 点击浏览框右上角X 清空文件前响应事件 $("#fileinput").on("fileclear",function(event, data, msg){ }); | |
filecleared | 点击浏览框右上角X 清空文件后响应事件 $("#fileinput").on("filecleared",function(event, data, msg){ }); | |
fileimageuploaded | 在预览框中图片已经完全加载完毕后回调的事件 |
以上是"怎么使用bootstrap-fileinput实现文件上传"这篇文章的所有内容,感谢各位的阅读!希望分享的内容对大家有帮助,更多相关知识,欢迎关注行业资讯频道!