ajax實現非同步檔案或圖片上傳功能執行個體分享

來源:互聯網
上載者:User
本文主要為大家詳細介紹了ajax實現非同步檔案(圖片)上傳功能,具有一定的參考價值,感興趣的小夥伴們可以參考一下,希望能協助到大家。

眾所周知現在的各大網站基本都設有檔案上傳功能,使用者可以把自己喜歡的圖片或其他檔案放在網上存起來,以便以後用的時候方便去找,可是一個網頁的檔案上傳功能究竟該怎麼去設定呢?今天我就以圖片上傳為例向大家展示檔案上傳功能的具體步驟。

其實檔案上傳有兩種方法,一種是from表單submit提交,一種是ajax實現非同步提交,可是form表單提交有個問題就是每次在上傳完成時會重新整理介面,不能實現非同步上傳,所以現在幾乎所有網站都採用ajax非同步上傳,現在我給大家展示ajax非同步上傳該如何?。

首先我先建立一個form表單,代碼如下:


 <form action="" id="form">  使用者名稱:<input type="text" name="user"/></br>  密碼:<input type="password" name="pass" /></br>  性別:<input type="radio" name="sex" value="男"/>男   <input type="radio" name="sex" value="女"/>女  頭像:<input type="file" id="file" name="file"/></br>  <button id="btn" type="button">提交</button> </form> <p class="con"></p>

建立完成後,首先我們要先拿到使用者從本上傳的圖片的資訊,代碼如下


var imgs=[];//儲存圖片連結 //為檔案上傳添加change事件 var fileM=document.querySelector("#file"); $("#file").on("change",function(){  console.log(fileM.files);  //擷取檔案對象,files是檔案選取控制項的屬性,儲存的是檔案選取控制項選取的檔案對象,類型是一個數組  var fileObj=fileM.files[0];  //建立formdata對象,formData用來儲存表單的資料,表單資料時以索引值對形式儲存的。  var formData=new FormData();  formData.append('file',fileObj);

這裡的formData就是我們現在要的隱藏檔資訊的對象,然後我們需要把它用ajax請求提交給後台:


  //建立ajax對象  var ajax=new XMLHttpRequest();  //發送POST請求  ajax.open("POST","http://localhost/phpClass/file-upload/move_file.php",true);  ajax.send(formData);  ajax.onreadystatechange=function(){  if (ajax.readyState == 4) {   if (ajax.status>=200 &&ajax.status<300||ajax.status==304) {   console.log(ajax.responseText);   var obj=JSON.parse(ajax.responseText);   alert(obj.msg);   if(obj.err == 0){、    //上傳成功後自動動建立img標籤放在指定位置    var img =$("<img src='"+obj.msg+"' alt='' />");    $(".con").append(img);    imgs.push(obj.msg);   }else{    alert(obj.msg);   }   }  }  } });

然後我們請求成功後,後台肯定要做出相應的處理,並且把圖片存到指定的檔案夾裡,所以相應的PHP應該完成這些操作:


<?php//解決跨域問題header("Access-Control-Allow-Origin:*");//說明向前台返回的資料類型為JSONheader("Content-type:text/json");//$_FILES超全域變數儲存是檔案資料,是一個關聯陣列 $fileObj=$_FILES['file']; var_dump($fileObj); if($fileObj["error"]==0){ //判斷檔案是否合法 $types=["jpg","jpeg","png","gif"]; $type = explode("/", $fileObj["type"])[1]; if(in_array($type, $types)){  $time = time();//擷取時間戳記 返回一個整形  //擷取檔案詳細路徑  $filePath="http://localhost/phpClass/image1".$time.".".$type;  echo $filePath;  //移動檔案  $res=move_uploaded_file($fileObj["tmp_name"],"../image1/".$time.".".$type);  if($res){  $infor=array("err"=>0,"msg"=>"檔案移動成功");  }else{  $infor=array("err"=>1,"msg"=>"檔案移動失敗");  } }else{  $infor=array("err"=>1,"msg"=>"檔案格式不合法"); } echo json_encode($infor); }?>

這樣我們就完成了檔案上傳的所有步驟,如果你想把自己喜歡的圖片,上傳到自己的網頁上,希望這段代碼可以協助到你!

附:如果上傳檔案時還要附帶上你的其它資訊,你只需再前端頁面請求完成後加上這段代碼即可實現:


//完成form表單資料的提交 $('#btn').on('click',function(){//  serializeArray()將form表單控制項中的資料序列化成數組,數組中含有若干對象,對象包含對應控制項的name和value  var infor = $('#form').serializeArray();//  console.log(infor);  var stu = {};  for (var i=0;i<infor.length;i++) {  var obj=infor[i];  stu[obj.name] = obj.value;  }  stu["imgs"] = imgs;  stu["imgs"] = imgs[0];  //發送ajax請求  $.ajax({  url:"http://localhost/phpClass/file-upload/data.php",  data:{   parameter :JSON.stringify(stu)  },  success:function(res){   console.log(res.msg);  }  }); });

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.