zoukankan      html  css  js  c++  java
  • 详解bootstrap-fileinput文件上传控件的亲身实践

    经理让我帮服务器开发人员开发一个上传文件功能界面,我就想着以前使用过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、使用

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

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

    js文件操作

    ?
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    19
    $('#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,就是为了让两个文件同步上传,后台用数组一次接收。同步和异步上传成功结果处理的方法都是不同的

    异步上传错误结果处理

    ?
    1
    2
    3
    $('#uploadfile').on('fileerror', function(event, data, msg) {
     
    });

    异步上传成功结果处理

    ?
    1
    2
    3
    $("#uploadfile").on("fileuploaded", function (event, data, previewId, index) {
     
    })

    同步上传错误结果处理

    ?
    1
    2
    3
    $('#uploadfile').on('filebatchuploaderror', function(event, data, msg) {
     
    });

    同步上传成功结果处理

    ?
    1
    2
    3
    $('#uploadfile').on('filebatchuploadsuccess', function(event, data, previewId, index) {
     
    });

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

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

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

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

    ?
    1
    2
    3
    4
    layoutTemplates: {
          actionUpload: ''//就是让文件上传中的文件去除上传按钮
    //      actionDelete: '',//去除删除按钮
        },
  • 相关阅读:
    vuex中store分文件时候index.js进行文件整合
    vuex使用 实现点击按钮进行加减
    页面跳转时候拼接在url后面的多个 参数获取
    vue知识点2018.6.3
    vue项目中,main.js,App.vue,index.html如何调用
    locatin
    Json
    Python3基础 list 访问列表中的列表的元素
    Python3基础 list 索引查看元素
    Python3基础 list 查看filter()返回的对象
  • 原文地址:https://www.cnblogs.com/good10000/p/10583362.html
Copyright © 2011-2022 走看看