jquery+ajax实现上传图片并显示上传进度功能【附
网络编程 2021-07-04 15:50www.168986.cn编程入门
这篇文章主要介绍了jquery+ajax实现上传图片并显示上传进度功能,结合实例形式分析了jQuery+ajax结合layer.js插件与php后台交互,实现显示上传进度的相关操作技巧,需要的朋友可以参考下
本文实例讲述了jquery+ajax实现上传图片并显示上传进度功能。分享给大家供大家参考,具体如下
jquery上传文件用的formdata,上传进度条需要添加xhr的onprogress
html代码如下
<!DOCTYPE html> <html lang="zh-CN"> <head> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0, user-scalable=no"> <title>Ding Jianlong Html</title> <link href="https://cdnjs.cloudflare./ajax/libs/layer/2.3/skin/layer.css" rel="external nofollow" rel="stylesheet"> <script src="https://cdnjs.cloudflare./ajax/libs/jquery/3.3.1/jquery.min.js"></script> <script src="https://cdnjs.cloudflare./ajax/libs/layer/2.3/layer.js"></script> </head> <body> <!-- 外层div 进度条的整体视觉和位置设置 --> <div style="width:300px;height: 20px;border: 1px solid #CCC;"> <!-- 内层div 逐渐递增的进度条 --> <div id="jdt" style="height: 20px;"></div> </div> <p>总大小<span id="total"></span>;已上传<span id="loaded"></span>;</p><br> <form id="mainForm"> 选择文件<input type="file" name="file"> <input type="button" value="上传" onclick="upload()"> </form> <script> var uploading = false; function upload(){ //封装一个方法 传入一个监听函数 返回一个绑定了监听函数的XMLHttpRequest对象 var xhrOnProgress=function(fun) { xhrOnProgress.onprogress = fun; //绑定监听 //使用闭包实现监听绑 return function() { //通过$.ajaxSettings.xhr();获得XMLHttpRequest对象 var xhr = $.ajaxSettings.xhr(); //判断监听函数是否为函数 if (typeof xhrOnProgress.onprogress !== 'function') return xhr; //如果有监听函数并且xhr对象支持绑定时就把监听函数绑定上去 if (xhrOnProgress.onprogress && xhr.upload) { xhr.upload.onprogress = xhrOnProgress.onprogress; } return xhr; } } var data = new FormData($('#mainForm')[0]); //要加【0】 console.log(data); if(uploading){ layer.alert("文件正在上传中,请稍候"); return false; } $.ajax({ type: 'POST', url: 'upload_file.php', //当前路径 data: data, dataType: 'json', processData: false, //序列化,no contentType: false, //不设置内容类型 beforeSend: function(){ uploading = true; }, //进度条要调用原生xhr xhr:xhrOnProgress(function(evt){ var percent = Math.floor(evt.loaded / evt.total100);//计算百分比 console.log(percent); // 设置进度条样式 $('#jdt').css('width',percent 3 + 'px'); $('#jdt').css('background','skyblue'); //显示进度百分比 $('#jdt').text(percent+'%'); $('#loaded').text(evt.loaded/1024 + 'K'); $('#total').text(evt.total/1024 + 'K'); }), suess: function (data) { if (data.code == 200) { layer.msg(data.message, {icon: 1, time: 1000}); //成功后关闭修改页 setTimeout(function(){ var index = parent.layer.getFrameIndex(window.name); //先得到当前iframe的索引 parent.layer.close(index); //在执行关闭 } ,2000); //还有刷新下iframe的界面 parent.location.reload(); } else { layer.msg(data.message, {icon: 2, time: 3000}); } uploading = false; }, error: function (data) { alert('服务异常,请稍后重试'); console.log(data); } }); } </script> </body> </html>
php代码如下
<?php header('content-type:text/html;charset=utf-8'); if ($_FILES["file"]["error"] > 0) { echo "Return Code: " . $_FILES["file"]["error"] . "<br />"; } else { // 文件中文转码 //iconv('utf-8', 'gbk', $_FILES["file"]["name"]); //取出后缀名 $ext = strrchr($_FILES["file"]["name"],'.'); move_uploaded_file($_FILES["file"]["tmp_name"], "upload/" . uniqid() . $ext); $arr['code'] = 666; $arr['message'] = "已经保存到: " . "upload/" . uniqid() . $ext; echo json_encode($arr);die; }
参考资料:
更多关于jQuery相关内容感兴趣的读者可查看本站专题《》、《》、《》、《》及《》
希望本文所述对大家jQuery程序设计有所帮助。
编程语言
- 如何快速学会编程 如何快速学会ug编程
- 免费学编程的app 推荐12个免费学编程的好网站
- 电脑怎么编程:电脑怎么编程网咯游戏菜单图标
- 如何写代码新手教学 如何写代码新手教学手机
- 基础编程入门教程视频 基础编程入门教程视频华
- 编程演示:编程演示浦丰投针过程
- 乐高编程加盟 乐高积木编程加盟
- 跟我学plc编程 plc编程自学入门视频教程
- ug编程成航林总 ug编程实战视频
- 孩子学编程的好处和坏处
- 初学者学编程该从哪里开始 新手学编程从哪里入
- 慢走丝编程 慢走丝编程难学吗
- 国内十强少儿编程机构 中国少儿编程机构十强有
- 成人计算机速成培训班 成人计算机速成培训班办
- 孩子学编程网上课程哪家好 儿童学编程比较好的
- 代码编程教学入门软件 代码编程教程