91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

ajax怎么實現異步文件或圖片上傳功能

發布時間:2021-05-18 14:08:06 來源:億速云 閱讀:156 作者:小新 欄目:web開發

這篇文章主要介紹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>
 <div class="con"></div>

創建完成后,首先我們要先拿到用戶從本上傳的圖片的信息,代碼如下

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:*");
//說明向前臺返回的數據類型為JSON
header("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);
  }
  });
 });

什么是ajax

ajax是一種在無需重新加載整個網頁的情況下,能夠更新部分網頁的技術,可以通過在后臺與服務器進行少量數據交換,使網頁實現異步更新。

以上是“ajax怎么實現異步文件或圖片上傳功能”這篇文章的所有內容,感謝各位的閱讀!希望分享的內容對大家有幫助,更多相關知識,歡迎關注億速云行業資訊頻道!

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

长春市| 贞丰县| 闻喜县| 炎陵县| 淳安县| 宁河县| 泽普县| 宜州市| 大丰市| 裕民县| 砀山县| 中江县| 长治县| 西平县| 正安县| 宜兰县| 蛟河市| 闸北区| 宁乡县| 临清市| 古丈县| 孟津县| 柘荣县| 金堂县| 博罗县| 怀集县| 武义县| 阜宁县| 乐都县| 桐梓县| 崇仁县| 赣榆县| 舟曲县| 凤山县| 锡林郭勒盟| 永城市| 克什克腾旗| 宁晋县| 龙海市| 伊宁县| 祁阳县|