国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁(yè) > 開(kāi)發(fā) > AJAX > 正文

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

2024-09-01 08:27:27
字體:
來(lái)源:轉(zhuǎn)載
供稿:網(wǎng)友

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

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

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

首先我先創(chuàng)建一個(gè)form表單,代碼如下:

 <form action="" id="form">  用戶(hù)名:<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)建完成后,首先我們要先拿到用戶(hù)從本上傳的圖片的信息,代碼如下

var imgs=[];//存儲(chǔ)圖片鏈接 //為文件上傳添加change事件 var fileM=document.querySelector("#file"); $("#file").on("change",function(){  console.log(fileM.files);  //獲取文件對(duì)象,files是文件選取控件的屬性,存儲(chǔ)的是文件選取控件選取的文件對(duì)象,類(lèi)型是一個(gè)數(shù)組  var fileObj=fileM.files[0];  //創(chuàng)建formdata對(duì)象,formData用來(lái)存儲(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//解決跨域問(wèn)題header("Access-Control-Allow-Origin:*");//說(shuō)明向前臺(tái)返回的數(shù)據(jù)類(lèi)型為JSONheader("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); }?>            
發(fā)表評(píng)論 共有條評(píng)論
用戶(hù)名: 密碼:
驗(yàn)證碼: 匿名發(fā)表
主站蜘蛛池模板: 安阳县| 额敏县| 兰西县| 大港区| 历史| 台东市| 武邑县| 阿拉善盟| 闽清县| 凯里市| 内江市| 延津县| 太和县| 广德县| 旺苍县| 北安市| 砀山县| 石楼县| 津市市| 遂宁市| 康定县| 屏山县| 商都县| 宁津县| 凉山| 云安县| 崇文区| 东乌珠穆沁旗| 斗六市| 盐源县| 四会市| 大石桥市| 吉木乃县| 闻喜县| 漳浦县| 九江市| 富川| 休宁县| 裕民县| 彩票| 石河子市|