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 相关文章推荐
(function(){})()的用法与优点
Mar 11 Javascript
javascript中用星号表示预录入内容的实现代码
Jan 08 Javascript
JavaScript中变量提升 Hoisting
Jul 03 Javascript
JS实现不规则TAB选项卡效果代码
Sep 16 Javascript
ANGULARJS中使用JQUERY分页控件
Sep 16 Javascript
JavaScript获取IP获取的是IPV6 如何校验
Jun 12 Javascript
angular+bootstrap的双向数据绑定实例
Mar 03 Javascript
微信小程序 chooseImage选择图片或者拍照
Apr 07 Javascript
vue中axios的封装问题(简易版拦截,get,post)
Jun 15 Javascript
基于Vue-cli快速搭建项目的完整步骤
Nov 03 Javascript
ES6使用 Array.includes 处理多重条件用法实例分析
Mar 02 Javascript
JS+css3实现幻灯片轮播图
Aug 14 Javascript
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不用正则采集速度探究总结
2008/03/24 PHP
PHP数据类型之布尔型的介绍
2013/04/28 PHP
PHP 下载文件时如何自动添加bom头及解释BOM头和去掉bom头的方法
2016/01/04 PHP
CodeIgniter配置之SESSION用法实例分析
2016/01/19 PHP
PHP实现的折半查找算法示例
2017/12/19 PHP
Nigma vs Alliance BO5 第一场2.14
2021/03/10 DOTA
网上抓的一个特效
2007/05/11 Javascript
JS getMonth()日期函数的值域是0-11
2010/02/15 Javascript
一步一步制作jquery插件Tabs实现过程
2010/07/06 Javascript
代码触发js事件(click、change)示例应用
2013/12/13 Javascript
javascript浏览器兼容教程之事件处理
2014/06/09 Javascript
10分钟学会写Jquery插件实例教程
2014/09/06 Javascript
为什么JavaScript没有块级作用域
2016/05/22 Javascript
AngularJS 自定义指令详解及示例代码
2016/08/17 Javascript
微信小程序 常用工具类详解及实例
2017/02/15 Javascript
Vue的百度地图插件尝试使用
2017/09/06 Javascript
vue获取验证码倒计时组件
2019/08/26 Javascript
Python SQLite3数据库操作类分享
2014/06/10 Python
Python通过RabbitMQ服务器实现交换机功能的实例教程
2016/06/29 Python
Ubuntu下创建虚拟独立的Python环境全过程
2017/02/10 Python
Python基于scapy实现修改IP发送请求的方法示例
2017/07/08 Python
python使用opencv读取图片的实例
2017/08/17 Python
Python针对给定字符串求解所有子序列是否为回文序列的方法
2018/04/21 Python
Win10系统下安装labelme及json文件批量转化方法
2019/07/30 Python
使用Python快乐学数学Github万星神器Manim简介
2019/08/07 Python
Python3 venv搭建轻量级虚拟环境的步骤(图文)
2019/08/09 Python
Python注释、分支结构、循环结构、伪“选择结构”用法实例分析
2020/01/09 Python
Python中logger日志模块详解
2020/08/04 Python
Python脚本实现Zabbix多行日志监控过程解析
2020/08/26 Python
中英双版中文教师求职信
2013/10/27 职场文书
中学生学雷锋演讲稿
2014/04/26 职场文书
质监局领导班子对照检查材料思想汇报
2014/09/27 职场文书
党的群众路线教育实践活动个人对照检查材料(乡镇)
2014/11/05 职场文书
2014年教育实习工作总结
2014/11/22 职场文书
大学生暑假实习总结
2015/07/13 职场文书
使用Python获取字典键对应值的方法
2022/04/26 Python