以下脚本在Safari,Chrome和Firefox中执行并正常运行 - 但在IE8中则不行。不幸的是IE8是我的目标浏览器之一,所以这有点问题。由于我没有很多使用Ajax的经验,所以我不确定从哪里开始寻找。
我注意到IE在第15行报告了一个错误(用**标记),这实际上没有意义,因为if-else应该阻止它甚至查看该行。
function getNames(str) {
var xmlhttp;
// Clear previous queries
if(str.length == 0){
document.getElementById("txtHint").innerHTML = "";
return;
// Due to the high number of possible hits we'll demand 3 chars
// before we start querying.
}else if(str.length < 3){
return ;
}
if (window.XMLHttpRequest){ // code for IE7+, Firefox, Chrome, Opera, Safari
xmlhttp = new XMLHttpRequest();
}else{ // code for IE6, IE5
**xmlhttp = new ActiveXObject("Microsoft.XMLHTTP");**
}
xmlhttp.onreadystatechange = function (){
if(xmlhttp.status == 200 && xmlhttp.readyState == 4){
// String from get_names.php is comma separated
var arr = xmlhttp.responseText.split(",");
// The UL list we want our names in
var ul = document.getElementById("names");
// Clear the list for each key in
if(ul.hasChildNodes()){
while(ul.childNodes.length >= 1){
ul.removeChild(ul.firstChild);
}
}
// Step trough the String in Array form
for(var i = 0; i < arr.length; i++){
// :@ means that we've reached the end of applicable names.
if (arr[i] != ":@") {
var li = document.createElement("li");
li.innerHTML = newListItem = arr[i];
// Inserts the current name into the list.
ul.insertBefore(li, ul.getElementsByTagName("li")[0]);
}
}
}
}
xmlhttp.open("GET", "./ext/get_names.php?q=" + str, true);
xmlhttp.send();
}
答案 0 :(得分:0)
您应首先检查readyState,然后然后检查状态。这是在大多数浏览器中报告但忽略的常见错误。我不确定这是否是您问题的解决方案,但由于您没有提供错误消息,因此很难为您提供进一步的帮助。
if(xmlhttp.readyState == 4 && xmlhttp.status == 200) {
// Code ...
}
答案 1 :(得分:0)
据我所知,&#39; window.XMLHttpRequest&#39; -check应该没问题。
您可以尝试查看this回答。在这种情况下,问题是在浏览器设置中禁用了本机xmlhttprequest。