我正在做一個Ajax的jQuery函數如下:遺漏的類型錯誤:無法讀取空的特性「documentElement」,AJAX
$('.change').live('click',function(){
$('html, body').animate({
scrollTop: $("h4").offset().top
}, 2000);
$('h4').text("Edit Your Video Here :");
$('.drop').text("Drop Your Updated Video Here...");
$('.btn').text("Update");
var videoID = this.id;
xhr1 = new XMLHttpRequest();
//initiate request
xhr1.open('post','beforeUpdate.php',true);//true for asynchronous
xhr1.setRequestHeader('Content-Type',"multipart/form-data");
xhr1.setRequestHeader('vidID',videoID);
xhr1.onreadystatechange = handleResponse;
xhr1.send(null);
});
function handleResponse()
{
if(xhr1.readyState==4)//processing done
{
if(xhr1.status == 200)//response okie
{
var xmlResponse = xhr1.responseXML;
root= xmlResponse.documentElement;
var id = root.getElementsByTagName("ID");
var name = root.getElementsByTagName("Nama");
console.log("ID From Server : "+id);
console.log("Name From Server : "+name);
}
}
}
所以被點擊我的按鈕{類=變化}時,它會要發送ID來beforeUpdate.php,並在此PHP文件我生成將被送回xhr1.onreadystatechange = handleResponse;
這是我beforeUpdate.php文件的XML文件:
<?php
require 'databaseConnection.php';
openConnection();
$headers = apache_request_headers();
$ID = $headers['vidID'];
$hasil = mysql_query("SELECT * FROM video_management where id=$ID");
$result = mysql_fetch_array($hasil);
//$test = "ID = ".$ID."\r\n"."Name = ".$result['Nama'];
//fwrite($myfile, $test);
//fclose($myfile);
//Generating XML FILE
header('Content-Type: text/xml');
echo '<?xml version="1.0" encoding="UTF-8" standalone="yes" ?>';
echo '<response>';
echo '<ID>';
echo $ID;
echo '</ID>';
echo '<Name>';
echo $result['Nama'];
echo '</Name>';
echo '<Type>';
echo $result['Type'];
echo '</Type>';
echo '<Path>';
echo $result['videoPath'];
echo '</Path>';
echo '</response>';
closeConnection();
?>
沒有什麼錯誤的,當從數據庫中獲取數據,我可以獲取所有數據並將它們放到相關的xml元素中。
然後問題來自root= xmlResponse.documentElement;
據說Uncaught TypeError: Cannot read property 'documentElement' of null,
所以我在這裏做了什麼錯了......? 非常感謝你......! :)
注: 我的瀏覽器是Chrome的
xhr1.responseText給你什麼? – 2016-07-26 14:53:37
Oooowh ... yeaat ..我從responseText找到了一些東西...給我一下Squint先生... –
其實responseText包含了我的xml響應......這裏發生了什麼......? :v –