详解bootstrap-fileinput文件上传控件的亲身实践


Posted in Javascript onMarch 21, 2019

经理让我帮服务器开发人员开发一个上传文件功能界面,我就想着以前使用过bootstrap-fileinput插件进行文件上传,很不错。赶紧就撸起来了。

1、下载压缩包。插件地址https://github.com/kartik-v/bootstrap-fileinput/ ,下载压缩包解压之后,拿出fileinput.min.js、fileinput.min.css、和中文需要引用的插件zh.js,因为这款插件默认的语言是英语。把这几个文件引入进页面

2、文件的引入顺序

  • 引入bootstrap.min.css
  • 引入fileinput.min.css
  • 引入jquery,版本最好2以上
  • 引入bootstrap.min.js
  • 引入fileinput.min.js
  • 引入中文插件zh.js

3、使用

<div class="upload-wrap">
   <input type="file" id="md5File" multiple="multiple" name="test" />
</div>

将其设置为multiple,可以多选文件进行上传。

js文件操作

$('#md5File').fileinput({
    language: 'zh',
    uploadUrl: 'http://localhost:8080/sign',
    showCaption: true,//是否显示被选文件的简介
    showUpload: true,//是否显示上传按钮
    showRemove: true,//是否显示删除按钮
    showClose: true,//是否显示关闭按钮
    enctype: 'multipart/form-data',
    uploadAsync:false, //false 同步上传,后台用数组接收,true 异步上传,每次上传一个file,会调用多次接口 
    layoutTemplates: {
      actionUpload: ''//就是让文件上传中的文件去除上传按钮
//      actionDelete: '',//去除删除按钮
    },
    browseClass: 'btn btn-primary',
    maxFileCount: 2,
    minFileCount : 2,
  }).on('filebatchuploadsuccess',function(res) {
    console.log(res);
  });

需求是让选择两个文件进行上传,而且只能发起一次请求,所以这里让maxFileCount和minFileCount都设置为2,uploadAsync设置为false,就是为了让两个文件同步上传,后台用数组一次接收。同步和异步上传成功结果处理的方法都是不同的

异步上传错误结果处理

$('#uploadfile').on('fileerror', function(event, data, msg) {

});

异步上传成功结果处理

$("#uploadfile").on("fileuploaded", function (event, data, previewId, index) {

})

同步上传错误结果处理

$('#uploadfile').on('filebatchuploaderror', function(event, data, msg) {

});

同步上传成功结果处理

$('#uploadfile').on('filebatchuploadsuccess', function(event, data, previewId, index) { 

});

其实本来不难,但是我对于同步上传成功结果处理的函数一直没有处理对,打断点也捕捉不到,我也很纳闷在做的时候,我在很多地方看到的是如下的处理方法:

详解bootstrap-fileinput文件上传控件的亲身实践

我就一直使用$('#uploadfile').on('filepreupload',function(e,data,previewId,index){})这个方法,后来才恍然大悟,把filepreupload改成了filebatchuploadsuccess,最终才实现了同步上传成功结果处理。也算是一个小坑,被人误导,自己也没有看清楚。

这里面还有一个参数:layoutTemplates,这个参数是对上传的那多个文件里面操作

详解bootstrap-fileinput文件上传控件的亲身实践

如上图的红色圈圈,可以对这几个icon进行设置

layoutTemplates: {
      actionUpload: ''//就是让文件上传中的文件去除上传按钮
//      actionDelete: '',//去除删除按钮
    },

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jQuery文件上传插件Uploadify使用指南
Jun 05 Javascript
浅析javascript中函数声明和函数表达式的区别
Feb 15 Javascript
JQuery创建DOM节点的方法
Jun 11 Javascript
谈谈我对JavaScript DOM事件的理解
Dec 18 Javascript
关于javascript的一些知识以及循环详解
Sep 12 Javascript
jQuery+ajax的资源回收处理机制分析
Jan 07 Javascript
AngularJS报错$apply already in progress的解决方法分析
Jan 30 Javascript
利用vueJs实现图片轮播实例代码
Jun 03 Javascript
vue编译打包本地查看index文件的方法
Feb 23 Javascript
vue实现element-ui对话框可拖拽功能
Aug 17 Javascript
vue elementUI table 自定义表头和行合并的实例代码
May 22 Javascript
微信小程序实现下拉框功能
Jul 16 Javascript
详解基于React.js和Node.js的SSR实现方案
Mar 21 #Javascript
javascript中call()、apply()的区别
Mar 21 #Javascript
vue实现微信获取用户信息的方法
Mar 21 #Javascript
vue里如何主动销毁keep-alive缓存的组件
Mar 21 #Javascript
基于node简单实现RSA加解密的方法步骤
Mar 21 #Javascript
详解React项目如何修改打包地址(编译输出文件地址)
Mar 21 #Javascript
js实现unicode码字符串与utf8字节数据互转详解
Mar 21 #Javascript
You might like
Excel数据导入Mysql数据库的实现代码
2008/06/05 PHP
PHP使用GIFEncoder类生成gif动态滚动字幕
2014/07/01 PHP
PHP中header函数的用法及其注意事项详解
2016/06/13 PHP
javascript 写类方式之六
2009/07/05 Javascript
提高网站性能之 如何对待JavaScript
2009/10/31 Javascript
ModelDialog JavaScript模态对话框类代码
2011/04/17 Javascript
js将iframe中控件的值传到主页面控件中的实现方法
2013/03/11 Javascript
jQuery操作select下拉框的text值和value值的方法
2014/05/31 Javascript
jQuery+css3实现转动的正方形效果(附demo源码下载)
2016/01/27 Javascript
jquery动态遍历Json对象的属性和值的方法
2016/07/27 Javascript
微信小程序开发之录音机 音频播放 动画实例 (真机可用)
2016/12/08 Javascript
详解handlebars+require基本使用方法
2016/12/21 Javascript
js实现拖拽上传图片功能
2017/08/01 Javascript
详解如何使用nvm管理Node.js多版本
2019/05/06 Javascript
arctext.js实现文字平滑弯曲弧形效果的插件
2019/05/13 Javascript
vue 地区选择器v-distpicker的常用功能
2019/07/23 Javascript
layui中的switch开关实现方法
2019/09/03 Javascript
详解小程序横屏方案对比
2020/06/28 Javascript
python实现批量下载新浪博客的方法
2015/06/15 Python
使用Python保存网页上的图片或者保存页面为截图
2016/03/05 Python
儿童python练习实例
2018/05/27 Python
python把ipynb文件转换成pdf文件过程详解
2019/07/09 Python
分享一个pycharm专业版安装的永久使用方法
2019/09/24 Python
python实现飞机大战项目
2020/03/11 Python
给ubuntu18安装python3.7的详细教程
2020/06/08 Python
python 图像插值 最近邻、双线性、双三次实例
2020/07/05 Python
python通过函数名调用函数的几种场景
2020/09/23 Python
CSS3轻松实现清新 Loading 效果的简单实例
2016/06/06 HTML / CSS
阿迪达斯丹麦官网:adidas丹麦
2016/10/01 全球购物
Tahari ASL官方网站:高级设计师女装
2021/03/15 全球购物
计算机专业个人简短的自我评价
2013/10/23 职场文书
祖国在我心中演讲稿300字
2014/05/04 职场文书
爱心募捐通知范文
2015/04/27 职场文书
小学英语教学经验交流材料
2015/11/02 职场文书
前端JS获取URL参数的4种方法总结
2022/04/05 Javascript
微信小程序APP页面的之间的相互传递参数以及自定义组件
2022/04/19 Javascript