大家好,這篇文章我要給大家分享一個網(wǎng)頁文件上傳功能的代碼,希望大家可以有所參考,或者給我提些建議。
眾所周知現(xiàn)在的各大網(wǎng)站基本都設(shè)有文件上傳功能,用戶可以把自己喜歡的圖片或其他文件放在網(wǎng)上存起來,以便以后用的時候方便去找,可是一個網(wǎng)頁的文件上傳功能究竟該怎么去設(shè)置呢?今天我就以圖片上傳為例向大家展示文件上傳功能的具體步驟。
其實文件上傳有兩種方法,一種是from表單submit提交,一種是ajax實現(xiàn)異步提交,可是form表單提交有個問題就是每次在上傳完成時會刷新界面,不能實現(xiàn)異步上傳,所以現(xiàn)在幾乎所有網(wǎng)站都采用ajax異步上傳,現(xiàn)在我給大家展示ajax異步上傳該如何實現(xiàn)。
首先我先創(chuàng)建一個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是文件選取控件的屬性,存儲的是文件選取控件選取的文件對象,類型是一個數(shù)組
var fileObj=fileM.files[0];
//創(chuàng)建formdata對象,formData用來存儲表單的數(shù)據(jù),表單數(shù)據(jù)時以鍵值對形式存儲的。
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.status300||ajax.status==304) {
console.log(ajax.responseText);
var obj=JSON.parse(ajax.responseText);
alert(obj.msg);
if(obj.err == 0){、
//上傳成功后自動動創(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ù),是一個關(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();//獲取時間戳 返回一個整形
//獲取文件詳細路徑
$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);
}
?>
這樣我們就完成了文件上傳的所有步驟,如果你想把自己喜歡的圖片,上傳到自己的網(wǎng)頁上,希望這段代碼可以幫助到你!
附:如果上傳文件時還要附帶上你的其它信息,你只需再前端頁面請求完成后加上這段代碼即可實現(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;iinfor.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);
}
});
});
更多精彩內(nèi)容請參考專題《ajax上傳技術(shù)匯總》進行學(xué)習(xí)。
以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
您可能感興趣的文章:- ajax圖片上傳,圖片異步上傳,更新實例
- ajax 異步上傳帶進度條視頻并提取縮略圖
- Ajax異步文件上傳與NodeJS express服務(wù)端處理
- Ajax異步上傳文件實例代碼分享
- ajax實現(xiàn)文件異步上傳并回顯文件相關(guān)信息功能示例
- jquery中的ajax異步上傳
- Ajax表單異步上傳文件實例代碼(包括文件域)
- 表單上傳功能實現(xiàn) ajax文件異步上傳
- ajax異步實現(xiàn)文件分片上傳實例代碼