原生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 相关文章推荐
一个封装js代码-----展开收起效果示例
Jul 03 Javascript
Jquery利用mouseenter和mouseleave实现鼠标经过弹出层且可以点击
Feb 12 Javascript
手机端网页点击链接触发自动拨打或保存电话的示例代码
Aug 15 Javascript
JavaScript实现Java中StringBuffer的方法
Feb 09 Javascript
JavaScript中setTimeout和setInterval函数的传参及调用
Mar 11 Javascript
浅谈Web页面向后台提交数据的方式和选择
Sep 23 Javascript
JavaScript构建自己的对象示例
Nov 29 Javascript
vue.js实例对象+组件树的详细介绍
Oct 20 Javascript
详解bootstrap导航栏.nav与.navbar区别
Nov 23 Javascript
layui点击导航栏刷新tab页的示例代码
Aug 14 Javascript
解决VUE双向绑定失效的问题
Oct 29 Javascript
js基于div丝滑实现贝塞尔曲线
Sep 23 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初学者写及时补给skype用户充话费的小程序
2008/11/02 PHP
Yii2框架中一些折磨人的坑
2019/12/15 PHP
自写的一个jQuery圆角插件
2010/10/26 Javascript
改进版通过Json对象实现深复制的方法
2012/10/24 Javascript
js 实现菜单左右滚动显示示例介绍
2013/11/21 Javascript
浅析XMLHttpRequest的缓存问题
2013/12/13 Javascript
JavaScript中的ubound函数使用实例
2014/11/04 Javascript
jquery使用Cookie和JSON记录用户最近浏览历史
2016/04/19 Javascript
AngularJS入门教程之Scope(作用域)
2016/07/27 Javascript
关于JavaScript限制字数的输入框的那些事
2016/08/14 Javascript
node.js中module.exports与exports用法上的区别
2016/09/02 Javascript
详解jQuery的Cookie插件
2016/11/23 Javascript
详解js几个绕不开的事件兼容写法
2017/08/30 Javascript
详解javascript appendChild()的完整功能
2018/08/18 Javascript
在Vue中使用axios请求拦截的实现方法
2018/10/25 Javascript
nodejs微信开发之接入指南
2019/03/17 NodeJs
js前端面试之同步与异步问题详解
2019/04/03 Javascript
Node.js系列之发起get/post请求(2)
2019/08/30 Javascript
layui 数据表格+分页+搜索+checkbox+缓存选中项数据的方法
2019/09/21 Javascript
JS使用正则表达式提交页面验证的代码
2019/10/16 Javascript
Vue实现导航栏的显示开关控制
2019/11/01 Javascript
vue 微信扫码登录(自定义样式)
2020/01/06 Javascript
星球大战与Python之间的那些事
2016/01/07 Python
Python实现MySQL操作的方法小结【安装,连接,增删改查等】
2017/07/12 Python
pandas将DataFrame的列变成行索引的方法
2018/04/10 Python
在Pycharm中项目解释器与环境变量的设置方法
2018/10/29 Python
python pands实现execl转csv 并修改csv指定列的方法
2018/12/12 Python
自定义django admin model表单提交的例子
2019/08/23 Python
Pyecharts 中Geo函数常用参数的用法说明
2021/02/01 Python
CSS3实现超酷的黑猫警长首页
2016/04/26 HTML / CSS
菲律宾旅游网站:Expedia菲律宾
2017/10/11 全球购物
输入一行文字,找出其中大写字母、小写字母、空格、数字、及其他字符各有多少
2016/04/15 面试题
大学毕业感言
2014/01/10 职场文书
商务英语广告词大全
2014/03/18 职场文书
婚内房产协议书范本
2014/10/02 职场文书
Python 匹配文本并在其上一行追加文本
2022/05/11 Python