This article mainly introduces the example of PHP+Ajax image upload without refresh with progress bar, and organizes the code of PHP image upload without refresh with progress bar in detail. If you need it, you can learn about it.
Project requirements: 1. PHP+Ajax image upload with progress bar without refresh, 2. With progress bar. Required plugins: jquery.js, jquery.form.js.
Recently I am working on a mobile web project, which requires the use of the Ajax upload function. The project requires PHP to upload images without refreshing and with a progress bar. Let me talk about my implementation method and see the effect first. Figure
This example requires the use of jquery.js, jquery.form.js, which are included in the demo. You can download them at the bottom of the article.
The first step is to create the front-end page index.html
This paragraph is the front-end display content. What needs to be explained here is that the input:file tag is not very beautiful, so I hide it. . And use an a tag .uploadbtn to call the click event of the file tag to open and select the file.
Note: When uploading files, the form attribute enctype must be set to: multipart/form-data
##
nbsp;HTML> <meta> <title>php-ajax无刷新上传(带进度条)demo</title> <meta> <meta> <script></script> <script></script> <link> <p> </p>
50%
点击上传文件<script> $(document).ready(function(e) { var progress = $(".progress"); var progress_bar = $(".progress-bar"); var percent = $('.percent'); $("#uploadphoto").change(function(){ $("#myupload").ajaxSubmit({ dataType: 'json', //数据格式为json beforeSend: function() { //开始上传 progress.show(); var percentVal = '0%'; progress_bar.width(percentVal); percent.html(percentVal); }, uploadProgress: function(event, position, total, percentComplete) { var percentVal = percentComplete + '%'; //获得进度 progress_bar.width(percentVal); //上传进度条宽度变宽 percent.html(percentVal); //显示上传进度百分比 }, success: function(data) { if(data.status == 1){ var src = data.url; var attstr= '<img src="'+src+'" alt="PHP+Ajax no refresh with progress bar image upload example" >'; $(".imglist").append(attstr); $(".res").html("上传图片"+data.name+"成功,图片大小:"+data.size+"K,文件地址:"+data.url); }else{ $(".res").html(data.content); } progress.hide(); }, error:function(xhr){ //上传失败 alert("上传失败"); progress.hide(); } }); }); }); </script>
$picname = $_FILES['uploadfile']['name']; $picsize = $_FILES['uploadfile']['size']; if ($picname != "") { if ($picsize > 2014000) { //限制上传大小 echo '{"status":0,"content":"图片大小不能超过2M"}'; exit; } $type = strstr($picname, '.'); //限制上传格式 if ($type != ".gif" && $type != ".jpg" && $type != "png") { echo '{"status":2,"content":"图片格式不对!"}'; exit; } $rand = rand(100, 999); $pics = uniqid() . $type; //命名图片名称 //上传路径 $pic_path = "images/". $pics; move_uploaded_file($_FILES['uploadfile']['tmp_name'], $pic_path); } $size = round($picsize/1024,2); //转换成kb echo '{"status":1,"name":"'.$picname.'","url":"'.$pic_path.'","size":"'.$size.'","content":"上传成功"}';