我已经做了很多搜索这个问题,但我找不到具体的答案。AJAX - 显示加载图像,直到数据库查询加载
我正在使用下面的代码来执行查询。查询需要1-6秒或更多时间来处理。在等待结果我希望用户知道某些事情正在工作:
<script language="javascript">
function ajaxRequest(){
var activexmodes=["Msxml2.XMLHTTP", "Microsoft.XMLHTTP"] //activeX versions to check for in IE
if (window.ActiveXObject){ //Test for support for ActiveXObject in IE first (as XMLHttpRequest in IE7 is broken)
for (var i=0; i<activexmodes.length; i++){
try{
return new ActiveXObject(activexmodes[i])
}
catch(e){
//suppress error
}
}
}
else if (window.XMLHttpRequest) // if Mozilla, Safari etc
return new XMLHttpRequest()
else
return false
}
</script>
<script language="javascript">
function ajaxget(){
var mygetrequest=new ajaxRequest()
mygetrequest.onreadystatechange=function(){
if (mygetrequest.readyState==4){
if (mygetrequest.status==200 || window.location.href.indexOf("http")==-1){
document.getElementById("result").innerHTML=mygetrequest.responseText
}
else{
alert("An error has occured making the request")
}
}
}
var namevalue=encodeURIComponent(document.getElementById("name").value)
mygetrequest.open("GET", "findclosestcityresults.php?location="+namevalue, true)
mygetrequest.send(null)
}
</script>
我试图沿着放码与在查询PHP中的AJAX加载图片,但没有将显示,直到内容完全加载。
谢谢。
编辑:
改变了一些基于下面的链接代码,仍然不能得到任何牵引...
<script language="javascript">
function ajaxget(){
var mygetrequest=new ajaxRequest()
mygetrequest.onreadystatechange=function(){
if (mygetrequest.readyState==0){
document.getElementById('result').innerHTML = '<img src="images/ajax_loader.gif" />';
}
if (mygetrequest.readyState==1){
document.getElementById('result').innerHTML = '<img src="images/ajax_loader.gif" />';
}
if (mygetrequest.readyState==2){
document.getElementById('result').innerHTML = '<img src="images/ajax_loader.gif" />';
}
if (mygetrequest.readyState==3){
document.getElementById('result').innerHTML = '<img src="images/ajax_loader.gif" />';
}
if (mygetrequest.readyState==4){
if (mygetrequest.status==200 || window.location.href.indexOf("http")==-1){
document.getElementById("result").innerHTML=mygetrequest.responseText
}
else{
alert("An error has occured making the request")
}
}
}
var namevalue=encodeURIComponent(document.getElementById("name").value)
mygetrequest.open("GET", "findclosestcityresults.php?location="+namevalue, true)
mygetrequest.send(null)
}
</script>
这真的是我第一次用JavaScript鬼混/ AJAX 。第一个代码示例是我在网上找到的。
再次感谢。
https://developer.mozilla.org/en/AJAX/Getting_Started - 阅读。您的问题的答案是在第2步。 – Dan
只是在调用AJAX之前显示图像的代码 –
@Dan谢谢你的抬头。我编辑了上面的代码,但我想我做得不对。 – Go3Team