layui文件上传进度条(模拟)

1.修改上传组件js(没测)

https://blog.csdn.net/weixin_42457316/article/details/81017471

https://www.cnblogs.com/youmingkuang/p/9183528.html

https://fly.layui.com/jie/19430/

1、upload.js 扩展

功能利用ajax的xhr属性实现
该功能修改过modules中的upload.js文件
功能具体实现:
在js文件中添加监听函数

    //创建监听函数
     var xhrOnProgress=function(fun) {
        xhrOnProgress.onprogress = fun; //绑定监听
         //使用闭包实现监听绑
        return function() {
            //通过$.ajaxSettings.xhr();获得XMLHttpRequest对象
            var xhr = $.ajaxSettings.xhr();
             //判断监听函数是否为函数
              if (typeof xhrOnProgress.onprogress !== ‘function‘)
                   return xhr;
               //如果有监听函数并且xhr对象支持绑定时就把监听函数绑定上去
                if (xhrOnProgress.onprogress && xhr.upload) {
                      xhr.upload.onprogress = xhrOnProgress.onprogress;
                }
                return xhr;
         }
     }

初始化上传

//初始化上传
 upload.render({
     elem: ‘上传地址‘
     ,url: path+‘/upload/uploadVideo.do‘
     ,accept: ‘video‘
    ,size: 512000
    ,auto:false
    ,xhr:xhrOnProgress
    ,progress:function(value){//上传进度回调 value进度值
        element.progress(‘demo‘, value+‘%‘)//设置页面进度条
     }
    ,bindAction:‘#uploadvideo‘
     ,before: function(input){
    //返回的参数item,即为当前的input DOM对象
        console.log(‘文件上传中‘);
    }
    ,done: function(res){
             //上传成功
           console.log(res)
     }
 });

修改modules中upload.js文件的ajax方法

 //提交文件
        $.ajax({
          url: options.url
          ,type: options.method
          ,data: formData
          ,contentType: false
          ,processData: false
          ,dataType: ‘json‘
          ,xhr:options.xhr(function(e){//此处为新添加功能
                var percent=Math.floor((e.loaded / e.total)*100);//计算百分比
                options.progress(percent);//回调将数值返回
           })
          ,success: function(res){
            successful++;
            done(index, res);
            allDone();
          }
          ,error: function(e){
             console.log(e)
            aborted++;
            that.msg(‘请求上传接口出现异常‘);
            error(index);
            allDone();
          }
        });

后台代码:

        public ActionResult UploadFiles(HttpPostedFileBase fileNames)
        {
            string path = "";
            //小于20M
            if (fileNames.ContentLength > 0 && fileNames.ContentLength <= 120971520)
            {

                var fileName = Path.GetFileName(fileNames.FileName);

                string q_FN = fileName.Substring(0, fileName.LastIndexOf("."));
                string h_FN = fileName.Substring(fileName.LastIndexOf("."));

                string NewFileName = q_FN + DateTime.Now.ToString("yyyyMMddHHmmss") + h_FN;

                path = Path.Combine(Server.MapPath("/Uploadfile/"), NewFileName);
                fileNames.SaveAs(path);

                path = "/Uploadfile/" + NewFileName;
                var relt = new { tc = path };
                return Content(JsonConvert.SerializeObject(relt));
            }
            else
            {
                var relt = new { tc = "上传文件要小于20M" };
                return Content(JsonConvert.SerializeObject(relt));
            }
        }

功能到此结束!!!

列子截图:

2.模拟一个假的进度条

https://blog.csdn.net/lin452473623/article/details/80784717

layui.use([‘upload‘,‘element‘,‘layer‘], function(){
	var upload = layui.upload,element = layui.element,layer = layui.layer;
	var timer;//定义一个计时器
	//选完文件后不自动上传
	upload.render({
	    elem: ‘#test8‘
	    ,url: ‘upload‘
	    ,async: false
	    ,method: ‘post‘
	    ,data: {
	        upgradeType: function(){
		    return $("input[name=‘upgradeType‘]:checked").val();//额外传递的参数
	        }
	    }
	    ,auto: false
	    ,accept: ‘file‘ //普通文件
	    ,exts: ‘zip‘ //只允许上传压缩文件
	    ,field:‘uploadFile‘
	    ,bindAction: ‘#test9‘
	    ,choose: function(obj){//这里的作用是截取上传文件名称并显示
		var uploadFileInput=$(".layui-upload-file").val();
		var uploadFileName=uploadFileInput.split("\\");
		$("#uploadName").text(uploadFileName[uploadFileName.length-1]);
	    }
	    ,before: function(obj){ //obj参数包含的信息,跟choose回调完全一致
		layer.load(); //上传loading
		var n = 0;
		timer = setInterval(function(){//按照时间随机生成一个小于95的进度,具体数值可以自己调整
		    n = n + Math.random()*10|0;
		    if(n>95){
			n = 95;
			clearInterval(timer);
		    }
		    element.progress(‘demo‘, n+‘%‘);
		}, 50+Math.random()*100);
	    }
	    ,done: function(res){
		clearInterval(timer);
		element.progress(‘demo‘, ‘100%‘);//一成功就把进度条置为100%
		layer.closeAll(); layer.msg(‘上传成功‘);}    ,error: function(index, upload){element.progress(‘demo‘, ‘0%‘);layer.closeAll(); //关闭所有层layer.msg(‘上传更新包失败‘);    }});});

  

参考:https://www.layui.com/doc/modules/upload.html

原文地址:https://www.cnblogs.com/liuqiyun/p/9517646.html

时间: 2024-08-12 23:50:12

layui文件上传进度条(模拟)的相关文章

Layui多文件上传进度条

Layui原生upload模块不支持文件上传进度条显示,百度,谷歌找了一下不太适用.后面找到一个别人修改好的JS,替换上去,修改一下页面显示即可使用,一下是部分代码 HTML: <div class="layui-upload"> <button type="button" class="layui-btn layui-btn-normal" id="fileList">选择多文件</button

基于HT for Web矢量实现HTML5文件上传进度条

在HTML中,在文件上传的过程中,很多情况都是没有任何的提示,这在体验上很不好,用户都不知道到时有没有在上传.上传成功了没有,所以今天给大家介绍的内容是通过HT for Web矢量来实现HTML5文件上传进度条,矢量在<矢量Chart图表嵌入HTML5网络拓扑图的应用>一文中已经讲述了关于setCompType()方法的应用,今天我们用setImage()方法充分利用系统中定义好的矢量资源来实现文件上传进度条,我们先来看下效果图: 从效果图可以看到,向服务器上传了一个mp4文件,并在最下方显示

Struts2 文件上传 进度条显示

参考成功博客:http://blog.sina.com.cn/s/blog_bca9d7e80101bkko.html 待测试博客:http://blog.csdn.net/z69183787/article/details/52536255 Struts2 文件上传 进度条显示

JQuery和Servlet实现文件上传进度条,能显示上传速度,上传的百分比等

原文:JQuery和Servlet实现文件上传进度条,能显示上传速度,上传的百分比等 源代码下载地址:http://www.zuidaima.com/share/1550463319542784.htm JQuery和Servlet实现文件上传进度条,能显示上传速度,上传的百分比等

spring定时任务-文件上传进度条

spring定时任务 导依赖 <!-- https://mvnrepository.com/artifact/org.quartz-scheduler/quartz --> <dependency> <groupId>org.quartz-scheduler</groupId> <artifactId>quartz</artifactId> <version>2.2.3</version> </depen

struts2实现文件上传进度条(前端JS+Java)(自我整理)

需要做一个文件上传进度的效果,结合网上资料和自己的实践后,这里做一个整理 步骤如下: 1.重写.自定义JakartaMultiPartRequest类 <span style="font-size:12px;">package com.hikvision.fileUploadProcess.interceptor; import java.io.IOException; import javax.servlet.http.HttpServletRequest; import

ajax文件上传进度条

写在前面: 思路:首先将表单提交servlet,servlet中做文件上传处理,上传的参数封装成对象存入session中,提交到的页面为隐藏的iframe窗口.然后使用ajax异步请求获取session中的对象,并将对象转换成json对象输出出来.当对象状态为上传完成或操作异常时将session中对应的属性清除掉.异步操作的回调函数可以使用var jinduStatus = eval("("+xmlHttp.responseText+")") 的方法将json转换为

实现一个简单的文件上传进度条

新手入门web 文件上传完成 取得的进展 没有进度条只能用文字 不好看  必须是一个进度条  没有艺术 互联网很 进度条 需要图片 有多种帧的 他看上去好麻烦 让自己的单纯 很简单 我没想到这么复杂  共享 jsp页面 <tr> <td width="100">图片</td> <td> <div style="width: 450px;"> <div class="file-box"

使用html5实现文件上传进度条

html <div id="file"> <input type="file" name="ver" id="ver"/> <font color="red">*(apk,ipa目前为自动重命名)</font><br /> <div class="progress"><span class="bgpr