欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

ajax實(shí)現(xiàn)異步文件或圖片上傳功能

 更新時(shí)間:2017年01月12日 14:07:17   作者:he2695  
這篇文章主要為大家詳細(xì)介紹了ajax實(shí)現(xiàn)異步文件(圖片)上傳功能,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下

大家好,這篇文章我要給大家分享一個(gè)網(wǎng)頁文件上傳功能的代碼,希望大家可以有所參考,或者給我提些建議。

眾所周知現(xiàn)在的各大網(wǎng)站基本都設(shè)有文件上傳功能,用戶可以把自己喜歡的圖片或其他文件放在網(wǎng)上存起來,以便以后用的時(shí)候方便去找,可是一個(gè)網(wǎng)頁的文件上傳功能究竟該怎么去設(shè)置呢?今天我就以圖片上傳為例向大家展示文件上傳功能的具體步驟。

其實(shí)文件上傳有兩種方法,一種是from表單submit提交,一種是ajax實(shí)現(xiàn)異步提交,可是form表單提交有個(gè)問題就是每次在上傳完成時(shí)會(huì)刷新界面,不能實(shí)現(xiàn)異步上傳,所以現(xiàn)在幾乎所有網(wǎng)站都采用ajax異步上傳,現(xiàn)在我給大家展示ajax異步上傳該如何實(shí)現(xiàn)。

首先我先創(chuàng)建一個(gè)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>

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

var imgs=[];//存儲(chǔ)圖片鏈接
 //為文件上傳添加change事件
 var fileM=document.querySelector("#file");
 $("#file").on("change",function(){
  console.log(fileM.files);
  //獲取文件對(duì)象,files是文件選取控件的屬性,存儲(chǔ)的是文件選取控件選取的文件對(duì)象,類型是一個(gè)數(shù)組
  var fileObj=fileM.files[0];
  //創(chuàng)建formdata對(duì)象,formData用來存儲(chǔ)表單的數(shù)據(jù),表單數(shù)據(jù)時(shí)以鍵值對(duì)形式存儲(chǔ)的。
  var formData=new FormData();
  formData.append('file',fileObj);

這里的formData就是我們現(xiàn)在要的存儲(chǔ)文件信息的對(duì)象,然后我們需要把它用ajax請(qǐng)求提交給后臺(tái):

  //創(chuàng)建ajax對(duì)象
  var ajax=new XMLHttpRequest();
  //發(fā)送POST請(qǐng)求
  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){、
    //上傳成功后自動(dòng)動(dòng)創(chuàng)建img標(biāo)簽放在指定位置
    var img =$("<img src='"+obj.msg+"' alt='' />");
    $(".con").append(img);
    imgs.push(obj.msg);
   }else{
    alert(obj.msg);
   }
   }
  }
  }
 });

然后我們請(qǐng)求成功后,后臺(tái)肯定要做出相應(yīng)的處理,并且把圖片存到指定的文件夾里,所以相應(yīng)的PHP應(yīng)該完成這些操作:

<?php
//解決跨域問題
header("Access-Control-Allow-Origin:*");
//說明向前臺(tái)返回的數(shù)據(jù)類型為JSON
header("Content-type:text/json");
//$_FILES超全局變量存儲(chǔ)是文件數(shù)據(jù),是一個(gè)關(guān)聯(lián)數(shù)組
 $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();//獲取時(shí)間戳 返回一個(gè)整形
  //獲取文件詳細(xì)路徑
  $filePath="http://localhost/phpClass/image1".$time.".".$type;
  echo $filePath;
  //移動(dòng)文件
  $res=move_uploaded_file($fileObj["tmp_name"],"../image1/".$time.".".$type);
  if($res){
  $infor=array("err"=>0,"msg"=>"文件移動(dòng)成功");
  }else{
  $infor=array("err"=>1,"msg"=>"文件移動(dòng)失敗");
  }
 }else{
  $infor=array("err"=>1,"msg"=>"文件格式不合法");
 }
 echo json_encode($infor);
 }
?>

這樣我們就完成了文件上傳的所有步驟,如果你想把自己喜歡的圖片,上傳到自己的網(wǎng)頁上,希望這段代碼可以幫助到你!

附:如果上傳文件時(shí)還要附帶上你的其它信息,你只需再前端頁面請(qǐng)求完成后加上這段代碼即可實(shí)現(xiàn):

//完成form表單數(shù)據(jù)的提交
 $('#btn').on('click',function(){
//  serializeArray()將form表單控件中的數(shù)據(jù)序列化成數(shù)組,數(shù)組中含有若干對(duì)象,對(duì)象包含對(duì)應(yīng)控件的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];

  //發(fā)送ajax請(qǐng)求
  $.ajax({
  url:"http://localhost/phpClass/file-upload/data.php",
  data:{
   parameter :JSON.stringify(stu)
  },
  success:function(res){
   console.log(res.msg);
  }
  });
 });

更多精彩內(nèi)容請(qǐng)參考專題《ajax上傳技術(shù)匯總》進(jìn)行學(xué)習(xí)。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

  • 揭開AJAX神秘的面紗(AJAX個(gè)人學(xué)習(xí)筆記)

    揭開AJAX神秘的面紗(AJAX個(gè)人學(xué)習(xí)筆記)

    寫這個(gè)學(xué)習(xí)筆記,只是記載一下自己的學(xué)習(xí)經(jīng)過和體會(huì),把一些學(xué)習(xí)重點(diǎn)記錄下來,以備今后的鞏固復(fù)習(xí)及應(yīng)用,很多知識(shí)點(diǎn)沒有詳細(xì)介紹,所以并不完全適用于初學(xué)者,如果你是初學(xué)者,最好選擇一本AJAX學(xué)習(xí)的書籍,然后與這篇學(xué)習(xí)筆記對(duì)照學(xué)習(xí),效果會(huì)更好。
    2009-09-09
  • ajax 怎么設(shè)置超時(shí)(一個(gè)action執(zhí)行了2遍)

    ajax 怎么設(shè)置超時(shí)(一個(gè)action執(zhí)行了2遍)

    一個(gè)action執(zhí)行了2遍 ,這個(gè)操作大致需要5分多鐘才能完成,于是搜了幾個(gè)可以設(shè)置超時(shí)的地方,希望對(duì)大家有所幫助
    2014-08-08
  • Ajax報(bào)錯(cuò)400的參考解決辦法

    Ajax報(bào)錯(cuò)400的參考解決辦法

    今天小編就為大家分享一篇關(guān)于Ajax報(bào)錯(cuò)400的參考解決辦法,小編覺得內(nèi)容挺不錯(cuò)的,現(xiàn)在分享給大家,具有很好的參考價(jià)值,需要的朋友一起跟隨小編來看看吧
    2018-10-10
  • 解決瀏覽器記住ajax請(qǐng)求并能前進(jìn)和后退問題

    解決瀏覽器記住ajax請(qǐng)求并能前進(jìn)和后退問題

    在我們?yōu)g覽不同網(wǎng)頁的時(shí)候,我們可以通過瀏覽器的前進(jìn)、后退鍵來去到我們前后訪問過的頁面。這篇文章主要介紹了讓瀏覽器記住ajax請(qǐng)求并能前進(jìn)和后退方法(一),需要的朋友可以參考下
    2017-06-06
  • AJAX級(jí)聯(lián)下拉框的簡(jiǎn)單實(shí)現(xiàn)案例

    AJAX級(jí)聯(lián)下拉框的簡(jiǎn)單實(shí)現(xiàn)案例

    本篇文章主要是對(duì)AJAX級(jí)聯(lián)下拉框的簡(jiǎn)單實(shí)現(xiàn)案例進(jìn)行了介紹,需要的朋友可以過來參考下,希望對(duì)大家有所幫助
    2014-02-02
  • AJAX和JSP實(shí)現(xiàn)的基于WEB的文件上傳的進(jìn)度控制代碼

    AJAX和JSP實(shí)現(xiàn)的基于WEB的文件上傳的進(jìn)度控制代碼

    AJAX和JSP實(shí)現(xiàn)的基于WEB的文件上傳的進(jìn)度控制代碼...
    2007-05-05
  • 使用Ajax實(shí)現(xiàn)進(jìn)度條的繪制

    使用Ajax實(shí)現(xiàn)進(jìn)度條的繪制

    這篇文章主要介紹了如何利用Ajax繪制進(jìn)度條,文中的示例代碼講解詳細(xì),對(duì)我們的學(xué)習(xí)或工作有一定的幫助,感興趣的小伙伴可以了解一下
    2022-04-04
  • Ajax修改數(shù)據(jù)即時(shí)顯示篇實(shí)現(xiàn)代碼

    Ajax修改數(shù)據(jù)即時(shí)顯示篇實(shí)現(xiàn)代碼

    上一篇我們講了如何使用ajax向數(shù)據(jù)庫添加數(shù)據(jù),今天我們要大家學(xué)習(xí)的課程是:使用ajax修改數(shù)據(jù)庫數(shù)據(jù),并在客戶網(wǎng)頁立即顯示新的內(nèi)容.當(dāng)然在修改的過程中同樣不會(huì)有刷新網(wǎng)頁的情況發(fā)生!
    2010-10-10
  • ajax跨頁面提交表單

    ajax跨頁面提交表單

    這篇文章主要為大家詳細(xì)介紹了ajax跨頁面提交表單的相關(guān)資料,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2016-10-10
  • ajax跨域(基礎(chǔ)域名相同)表單提交的方法

    ajax跨域(基礎(chǔ)域名相同)表單提交的方法

    這篇文章主要介紹了ajax跨域(基礎(chǔ)域名相同)表單提交的方法,實(shí)例分析了Ajax提交過程中表單跨域提交的技巧,需要的朋友可以參考下
    2015-05-05

最新評(píng)論