先看代碼:
頁面ajax post 提交代碼
$.post('goods_quickadd.php?action=update', {goods_code : $('#goods_code1').val(),goods_name : $('#goods_name1').val(),cat : $('#cat1').val(),pid : pid,weight : $('#weight').val(),rand : Math.random() },function(data){if(data == 1)alert('更新失敗');else{$('#title_' + pid).text($('#goods_code1').val() + ' ' + $('#goods_name1').val());$('#cat_' + pid).text($('#cat1').find("option:selected").text());}$.fancybox.close();})
post提交頁面幕後處理代碼:主要是資料庫操作,依資料庫操作結果返回0(成功)或1(失敗)
if($db->query($sql))echo 0;elseecho 1;exit;
以上代碼在Firefox執行正常,但在ie6,ie8下執行時前台頁面無變化。檢查後發現後台頁面執行正常(資料庫操作已執行)。也就是說IE中回呼函數不執行。
筆者ajax調用也用了一兩年,大多數使用的是get方法,get方法從未發生過這種事情。原想改為get方法試試,後又放棄了。因為在ecshop的二次開發中也碰到過類似的問題,也一直未找到真正的原因。
經多次調試,最終發現在後台頁面加上如下代碼,則IE中回呼函數可執行(PHP)。
header('Content-Type:text/html; charset=utf-8');header('Expires: Thu, 01 Jan 1970 00:00:01 GMT');header('Last-Modified: ' . gmdate('D, d M Y H:i:s') . ' GMT');header('Cache-Control: no-cache, must-revalidate, max-age=0');header('Pragma: no-cache');
也有可能只要以上語句中的一句就可以了,有興趣的童鞋可以一試。
希望以上方法對大家在實際工作中有用!