原生JS上传大文件显示进度条 php上传文件代码


Posted in Javascript onMarch 27, 2020

JS原生上传大文件显示进度条,php上传文件,供大家参考,具体内容如下

原生JS上传大文件显示进度条 php上传文件代码

在php.ini修改需要的大小:

upload_max_filesize = 8M   
post_max_size = 10M   
memory_limit = 20M 

<!DOCTYPE html>
<html>
<head>
 <title>原生JS大文件显示进度条</title>
 <meta charset="UTF-8">
 <style type="text/css">
 #parent{position: relative;width: 500px;height:20px;border:1px solid #ccc;display: none;border-radius:20px}
 #child{position: absolute;width:0%;height:20px;background: #5FB878;display: none;line-height: 20px;color: #ffffff;font-size: 12px;border-radius:20px}
 </style>
 <script type="text/javascript">
 function $(id){
  return document.getElementById(id);
 }
 </script>
</head>
<body>
 <form action="" method="post">
 <div id="parent">
  <div id="child"></div>
 </div>
 <p>上传文件:<input type="file" name="file"></p> 
 <p><input type="submit" value="提交" id="submit"></p>
 </form>
 <script type="text/javascript">
 var oForm = document.getElementsByTagName('form')[0];
 var oSubmit = $('submit');
 //如果多个人同时提交这个表单的时候,由于是异步的请求,互不影响
 oSubmit.onclick = function(){
  try{
  var xhr = new XMLHttpRequest();
  }catch(e){
  var xhr = new ActiveXObject("Msxml2.XMLHTTP");
  }
  xhr.upload.onprogress = function(e){
  var ev = e || window.event;
  var percent = Math.floor((ev.loaded / ev.total)*100); 
  // console.log(percent);
  //将百分比显示到进度条
  $('parent').style.display = 'block';
  $('child').style.display = 'block';
  //将上传进度的百分比显示到child里面
  $('child').style.width = percent+'%';
  $('child').style.textAlign = 'center';
  $('child').innerHTML = percent+'%';
  //判断如果百分比到达100%时候,隐藏掉
  if(percent==100){
   $('parent').style.display = 'none';
   $('child').style.display = 'none';
  }
  }
  xhr.open('post','progress.php',true);
  var form = new FormData(oForm);
  xhr.send(form);
  xhr.onreadystatechange = function(){
  if(xhr.readyState==4 && xhr.status==200){
   eval("var obj ="+xhr.responseText);
   if(obj.status){
   alert('上传成功');
   }else{
   alert('上传失败');
   }
  }
  }
  //阻止表单提交
  return false;
 }
 </script>
</body>
</html>
<?php
 //开始上传
 //注意:文件是windows系统的文件,采用的gbk编码,php文件使用的是utf-8编码
 //我们不能直接修改文件的编码,只能临时修改一下php的编码
 $dst_file = $_FILES['file']['name'];
 $dst_file = iconv('utf-8', 'gbk', $dst_file);
 if(move_uploaded_file($_FILES['file']['tmp_name'],$dst_file)){
 $data['status'] = 1;
 }else{
 $data['status'] = 0;
 }
 echo json_encode($data);

更多精彩内容请参考专题《ajax上传技术汇总》,《javascript文件上传操作汇总》和《jQuery上传操作汇总》进行学习。

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

Javascript 相关文章推荐
解密效果
Jun 23 Javascript
Js 导出table内容到Excel的简单实例
Nov 19 Javascript
js获取当前日期前七天的方法
Feb 28 Javascript
jQuery实现表格行上移下移和置顶的方法
May 22 Javascript
JS实现的论坛Ajax打分效果完整实例
Oct 31 Javascript
JavaScript程序开发之JS代码放置的位置
Jan 15 Javascript
React-Native中props具体使用详解
Sep 04 Javascript
浅谈Node.js之异步流控制
Oct 25 Javascript
JS遍历DOM文档树的方法实例详解
Apr 03 Javascript
解决vue打包后vendor.js文件过大问题
Jul 03 Javascript
js实现数字从零慢慢增加到指定数字示例
Nov 07 Javascript
Vuex的各个模块封装的实现
Jun 05 Javascript
vue中遇到的坑之变化检测问题(数组相关)
Oct 13 #Javascript
seaJs使用心得之exports与module.exports的区别实例分析
Oct 13 #Javascript
vue中axios处理http发送请求的示例(Post和get)
Oct 13 #Javascript
JavaScript实现随机数生成器(去重)
Oct 13 #Javascript
AngualrJs清除定时器遇到的坑
Oct 13 #Javascript
React Native中Navigator的使用方法示例
Oct 13 #Javascript
React Native中TabBarIOS的简单使用方法示例
Oct 13 #Javascript
You might like
PHP在XP下IIS和Apache2服务器上的安装
2006/09/05 PHP
PHP在网页中动态生成PDF文件详细教程
2014/07/05 PHP
php实现的操作excel类详解
2016/01/15 PHP
java模拟PHP的pack和unpack类
2016/04/13 PHP
PHP培训要多少钱
2017/06/06 PHP
thinkPHP框架中layer.js的封装与使用方法示例
2019/01/18 PHP
服务端 VBScript 与 JScript 几个相同特性的写法 By shawl.qiu
2007/03/06 Javascript
关于javascript DOM事件模型的两件事
2010/07/22 Javascript
PHP 与 js的通信(via ajax,json)
2010/11/16 Javascript
Javascript中 关于prototype属性实现继承的原理图
2013/04/16 Javascript
基于jquery实现的定时显示与隐藏div广告的实现代码
2013/08/22 Javascript
jquery(hide方法)隐藏指定元素实例
2013/11/11 Javascript
js+div实现图片滚动效果代码
2014/02/10 Javascript
通过js为元素添加多项样式,浏览器全兼容写法
2014/08/30 Javascript
jQuery中filter()方法用法实例
2015/01/06 Javascript
微信小程序 教程之数据绑定
2016/10/18 Javascript
详解javascript事件绑定使用方法
2016/10/20 Javascript
详解a++和++a的区别
2017/08/30 Javascript
react-native动态切换tab组件的方法
2018/07/07 Javascript
node.js中TCP Socket多进程间的消息推送示例详解
2018/07/10 Javascript
vue项目实现表单登录页保存账号和密码到cookie功能
2018/08/31 Javascript
详解JavaScript函数callee、call、apply的区别
2019/03/08 Javascript
python使用post提交数据到远程url的方法
2015/04/29 Python
Python使用正则表达式过滤或替换HTML标签的方法详解
2017/09/25 Python
Python中多个数组行合并及列合并的方法总结
2018/04/12 Python
pandas 小数位数 精度的处理方法
2018/06/09 Python
python 与服务器的共享文件夹交互方法
2018/12/27 Python
Python-while 计算100以内奇数和的方法
2019/06/11 Python
Pytorch卷积层手动初始化权值的实例
2019/08/17 Python
django实现web接口 python3模拟Post请求方式
2019/11/19 Python
如何用python 操作zookeeper
2020/12/28 Python
俄罗斯达美乐比萨外送服务:Domino’s Pizza
2020/12/18 全球购物
逻辑链路控制协议
2016/10/01 面试题
好军嫂事迹材料
2014/01/15 职场文书
运动会方阵口号
2014/06/07 职场文书
2016计划生育先进个人事迹材料
2016/02/29 职场文书