layui扩展上传组件模拟进度条的方法


Posted in Javascript onSeptember 23, 2019

如下所示:

<div id="uploadPatchForm" style="display:none" class="roundRect"> 
  <div id="uploadLoadingDiv">
    <div class="layui-progress" lay-showpercent="true" lay-filter="demo" >
	  <div class="layui-progress-bar layui-bg-red" lay-percent="0%"></div>
	</div>
  </div>
  <form class="layui-form" enctype="multipart/form-data">
	<div class="layui-form-item layui-upload">
	  <span id="uploadName" style="line-height: 3;"></span>
	  <button type="button" class="layui-btn layui-btn-normal" id="test8" style="float: right;">
        <i class="layui-icon">?</i>
      </button>
	</div>
	<div class="layui-form-item">
	  <div class="layui-input-block">
	    <input type="radio" name="upgradeType" value="30011001" title="手动升级">
	    <input type="radio" name="upgradeType" value="30011002" title="自动升级" checked>
	  </div>
	</div>
	<div class="layui-form-item">
	  <div class="layui-input-block">
		<a class="roundCornerDiv aLineGray" href="javascript:layer.closeAll();" rel="external nofollow" >
		  <span type="reset" class="ButtonText popupCloseBtn">取消</span>
		</a>
		<a class="roundCornerDiv aLineOrange">
	      <button class="ButtonText submitBtn" type="button" id="test9">立即提交</button>
	    </a> 
	  </div>
	</div>
  </form>
</div>
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('上传更新包失败');  }});});

哎,好难调格式!

效果如下,截图工具反应迟钝看起来有点失真,实际测试是ok的:

layui扩展上传组件模拟进度条的方法

以上这篇 layui扩展上传组件模拟进度条的方法就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
滚动图片效果 jquery实现回旋滚动效果
Jan 08 Javascript
判断一个对象是否为jquery对象的方法
Mar 12 Javascript
如何编写高质量JS代码
Dec 28 Javascript
jQuery代码实现对话框右上角菜单带关闭×
May 03 Javascript
jQuery EasyUI框架中的Datagrid数据表格组件结构详解
Jun 09 Javascript
微信小程序富文本渲染引擎的详解
Sep 30 Javascript
在vue项目中使用Nprogress.js进度条的方法
Jan 31 Javascript
ES6 中可以提升幸福度的小功能
Aug 06 Javascript
vue.js提交按钮时进行简单的if判断表达式详解
Aug 08 Javascript
深入理解Node内建模块和对象
Mar 12 Javascript
bootstrap+spring boot实现面包屑导航功能(前端代码)
Oct 09 Javascript
vue使用echarts图表自适应的几种解决方案
Dec 04 Vue.js
layer扩展打开/关闭动画的方法
Sep 23 #Javascript
layui字体图标 loading图标静止不旋转的解决方法
Sep 23 #Javascript
解决layer.confirm快速点击会重复触发事件的问题
Sep 23 #Javascript
小程序最新获取用户昵称和头像的方法总结
Sep 23 #Javascript
中级前端工程师必须要掌握的27个JavaScript 技巧(干货总结)
Sep 23 #Javascript
layui内置模块layim发送图片添加加载动画的方法
Sep 23 #Javascript
微信头像地址失效踩坑记附带解决方案
Sep 23 #Javascript
You might like
php简单实现多语言切换的方法
2016/05/09 PHP
php-fpm中max_children的配置
2019/03/15 PHP
php设计模式之组合模式实例详解【星际争霸游戏案例】
2020/03/27 PHP
Aster vs KG BO3 第一场2.19
2021/03/10 DOTA
js 获取中文拼音,Select自动匹配字母获取值的代码
2009/09/23 Javascript
js自定义事件及事件交互原理概述(一)
2013/02/01 Javascript
jquery组件使用中遇到的问题整理及解决
2014/02/21 Javascript
IE下双击checkbox反应延迟问题的解决方法
2014/03/27 Javascript
node.js中的path.join方法使用说明
2014/12/08 Javascript
深入解析AngularJS框架中$scope的作用与生命周期
2016/03/05 Javascript
JavaScript模拟push
2016/03/06 Javascript
20分钟成功编写bootstrap响应式页面 就这么简单
2016/05/12 Javascript
Servlet实现文件上传,可多文件上传示例
2016/12/05 Javascript
Vue实现virtual-dom的原理简析
2017/07/10 Javascript
浅谈node模块与npm包管理工具
2018/01/03 Javascript
获取layer.open弹出层的返回值方法
2018/08/20 Javascript
详解IOS微信上Vue单页面应用JSSDK签名失败解决方案
2018/11/14 Javascript
使用layer弹窗,制作编辑User信息页面的方法
2019/09/27 Javascript
使用Vue Composition API写出清晰、可扩展的表单实现
2020/06/10 Javascript
django通过ajax发起请求返回JSON格式数据的方法
2015/06/04 Python
Django模板变量如何传递给外部js调用的方法小结
2017/07/24 Python
基于Python开发chrome插件的方法分析
2018/07/07 Python
python-itchat 统计微信群、好友数量,及原始消息数据的实例
2019/02/21 Python
python下载微信公众号相关文章
2019/02/26 Python
python爬虫的一个常见简单js反爬详解
2019/07/09 Python
Django中Aggregation聚合的基本使用方法
2020/07/09 Python
详解HTML5中download属性的应用
2015/08/06 HTML / CSS
车祸赔偿收入证明
2014/01/09 职场文书
活动邀请函范文
2014/01/19 职场文书
运动会跳远加油稿
2014/02/20 职场文书
幼儿园教师的考核评语
2014/04/18 职场文书
2014年六一儿童节演讲稿
2014/05/23 职场文书
大学生第一学年自我鉴定
2014/09/12 职场文书
群众路线领导干部个人对照检查材料(集锦)
2014/09/23 职场文书
2015年学生会主席工作总结
2015/04/21 职场文书
2015年度信用社工作总结
2015/05/04 职场文书