PHP – jQuery 使用ajaxFileUpload套件的錯誤

使用 AJAX 上傳套件(Jquery Ajax File Uploader Version 2.1) 時遇到錯誤,這邊有好心的網友提供了說明….
主要是jquery版本中被拿掉handleError()的關係,以及加解JSON格式時的錯誤問題。按照這裡修改就成功了!
如果不用JSON格式而改用xml格式,那就不會發生這些問題囉!

 
請大家先參考過官方的範例檔:ajaxfileupload.php
先簡單說明其中的主要程式碼架構….

    function ajaxFileUpload()
    {
$("#loading") 
.ajaxStart(function(){
$(this).show();//上傳時的動畫
})
.ajaxComplete(function(){
$(this).hide();//上傳完畢的動畫
});
//開始上傳的程式碼
$.ajaxFileUpload
(
{
url:'doajaxfileupload.php', //接收上傳的php程式碼
secureuri:false, //不太清楚這個,應該是加密的什麼東西吧
fileElementId:'fileToUpload', //你的的id
dataType: 'json', //格式可選用xml或json,基本上我習慣用json
data:{name:'logan', id:'id'}, //你要夾帶的參數
success: function (data, status) //當成功時呼叫的funciton
{
if(typeof(data.error) != 'undefined')
{
if(data.error != '')
{
alert(data.error);
}else
{
alert(data.msg);
}
}
},
error: function (data, status, e) //失敗時呼叫的funciton
{
alert(e);
}
}
)

return false; //記得要false避免表單送出

    }

以上是官方的js,把json改成xml沒問題,但若要用json請參考大陸網友的說明吧!

——————————————————————————————————————————————————-

 


from : http://zhidao.baidu.com/question/351817654.html

——————————————————————————————————————————————————-

後來我還遇到小問題….
就是callback的時候,php使用json_encode(),會發生錯誤,
所以請網友注意一下上面改寫的這段…..eval("data = \" "+data+" \" ");
 
//如果php格式輸出的json格式長這樣{"act" : "hellow"} 那這裡要使用單引號 "data = \' "+data+" \' "
//如果php格式輸出的json格式長這樣{'act' : 'hellow'} 那這裡要使用雙引號 "data = \" "+data+" \" "
//因為PHP的json_encode是{"act" : "hellow"}所以我使用單引號"data = \' "+data+" \' "

 

發表迴響