php上传原生代码,php上传文件代码实现原生JS上传大文件显示进度条的示例

这篇文章主要为大家详细介绍了JS原生上传大文件显示进度条,php上传文件关键代码,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

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

7c8c824d2e26498ff32ad1fbe04f8482.png

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

upload_max_filesize = 8M

post_max_size = 10M

memory_limit = 20M

原生JS大文件显示进度条

#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}

function $(id){

return document.getElementById(id);

}

上传文件:

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;

}

//开始上传

//注意:文件是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);

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值