您好,登錄后才能下訂單哦!
這篇文章主要介紹ajax怎么實(shí)現(xiàn)異步文件或圖片上傳功能,文中介紹的非常詳細(xì),具有一定的參考價(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=[];//存儲圖片鏈接 //為文件上傳添加change事件 var fileM=document.querySelector("#file"); $("#file").on("change",function(){ console.log(fileM.files); //獲取文件對象,files是文件選取控件的屬性,存儲的是文件選取控件選取的文件對象,類型是一個(gè)數(shù)組 var fileObj=fileM.files[0]; //創(chuàng)建formdata對象,formData用來存儲表單的數(shù)據(jù),表單數(shù)據(jù)時(shí)以鍵值對形式存儲的。 var formData=new FormData(); formData.append('file',fileObj);
這里的formData就是我們現(xiàn)在要的存儲文件信息的對象,然后我們需要把它用ajax請求提交給后臺:
//創(chuàng)建ajax對象 var ajax=new XMLHttpRequest(); //發(fā)送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){、 //上傳成功后自動(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); } } } } });
然后我們請求成功后,后臺肯定要做出相應(yīng)的處理,并且把圖片存到指定的文件夾里,所以相應(yīng)的PHP應(yīng)該完成這些操作:
<?php //解決跨域問題 header("Access-Control-Allow-Origin:*"); //說明向前臺返回的數(shù)據(jù)類型為JSON header("Content-type:text/json"); //$_FILES超全局變量存儲是文件數(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í)還要附帶上你的其它信息,你只需再前端頁面請求完成后加上這段代碼即可實(shí)現(xiàn):
//完成form表單數(shù)據(jù)的提交 $('#btn').on('click',function(){ // serializeArray()將form表單控件中的數(shù)據(jù)序列化成數(shù)組,數(shù)組中含有若干對象,對象包含對應(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請求 $.ajax({ url:"http://localhost/phpClass/file-upload/data.php", data:{ parameter :JSON.stringify(stu) }, success:function(res){ console.log(res.msg); } }); });
ajax是一種在無需重新加載整個(gè)網(wǎng)頁的情況下,能夠更新部分網(wǎng)頁的技術(shù),可以通過在后臺與服務(wù)器進(jìn)行少量數(shù)據(jù)交換,使網(wǎng)頁實(shí)現(xiàn)異步更新。
以上是“ajax怎么實(shí)現(xiàn)異步文件或圖片上傳功能”這篇文章的所有內(nèi)容,感謝各位的閱讀!希望分享的內(nèi)容對大家有幫助,更多相關(guān)知識,歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。