AJAX setTimeout 在传递参数时不起作用
AJAX setTimeout not working when pass through parameters
用户输入一些东西然后使用ajax程序输出一些东西给用户。这主要是有效的,问题是通过参数将变量从我的脚本传递到远程函数。
当我将文本作为参数传入时,setTimeout
调用出错了。但是当我在 setTimeout
函数本身中输入它时,它起作用了:
function handleServerResponse(text){
if(xmlHttp.readyState==4){
if(xmlHttp.status==200){
xmlResponse = xmlHttp.responseXML; //izvlaci se xml sto smo dobili
xmlDocumentElement = xmlResponse.documentElement;
message = xmlDocumentElement.firstChild.data;
document.getElementById('underInput').innerHTML = message;
setTimeout("process(text)", 1000);
}else{
alert('Someting went wrong !');
}
}
}
全部代码:
<script type = "text/javascript">
var xmlHttp = createXmlHttpRequestObject();
function createXmlHttpRequestObject(){
var xmlHttp;
if(window.ActiveXObject){
try{
xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
}catch(e){
xmlHttp = false;
}
} else {
try{
xmlHttp = new XMLHttpRequest();
}catch(e){
xmlHttp = false;
}
}
if(!xmlHttp)
alert("Cant create that object !")
else
return xmlHttp;
}
function process(text){
//text = 'userInput';
if(xmlHttp.readyState==0 || xmlHttp.readyState==4){
food = encodeURIComponent(document.getElementById(text).value);
xmlHttp.open("GET", 'foodstore.php'+"?food="+food,true);
xmlHttp.onreadystatechange = function() {
handleServerResponse(text);
};
xmlHttp.send(null);
}else{
setTimeout("process(text)",1000);//cekaj 1s pa probaj opet
}
}
function handleServerResponse(text){
if(xmlHttp.readyState==4){
if(xmlHttp.status==200){
xmlResponse = xmlHttp.responseXML; //izvlaci se xml sto smo dobili
xmlDocumentElement = xmlResponse.documentElement;
message = xmlDocumentElement.firstChild.data;
document.getElementById('underInput').innerHTML = message;
setTimeout("process(text)", 1000);
}else{
alert('Someting went wrong !');
}
}
}
</script>
//*******************************************
<html>
<body onload = "process('userInput')">
<h3>The Chuff Bucker</h3>
Enter the food you would like to order:
<input type="text" id="userInput" />
<div id="underInput" />
</body>
</html>
尝试删除
中的“”
setTimeout("process(text)", 1000);
[编辑以供参考]
而不是像这个
setTimeout(function(){
process(text);
}, 1000);
您的 AJAX 查询过于复杂了。您完全可以使用 JQUERY 吗?它的语法非常简单,而且易于实施,可能会解决您的问题。请看这个例子。
AJAX JQUERY
的语法
var var_one = 'first post item here';
var var2 = $("#id_of_input_field").val();
///////// AJAX //////// AJAX //////////
$.ajax({
type: 'POST',
url: 'file_to_receive_post_vars.php',
data: {var_one:var_one, var2:var2},
success: function( response ){
alert('yay ajax!');
}//close succss params
});//close ajax
///////// AJAX //////// AJAX //////////
当您将字符串传递给 setTimeout
时,它会在全局范围内进行评估。没有全局 text
变量,所以调用会失败。而是传递一个函数:
setTimeout(function() {
process(text);
}, 1000);
用户输入一些东西然后使用ajax程序输出一些东西给用户。这主要是有效的,问题是通过参数将变量从我的脚本传递到远程函数。
当我将文本作为参数传入时,setTimeout
调用出错了。但是当我在 setTimeout
函数本身中输入它时,它起作用了:
function handleServerResponse(text){
if(xmlHttp.readyState==4){
if(xmlHttp.status==200){
xmlResponse = xmlHttp.responseXML; //izvlaci se xml sto smo dobili
xmlDocumentElement = xmlResponse.documentElement;
message = xmlDocumentElement.firstChild.data;
document.getElementById('underInput').innerHTML = message;
setTimeout("process(text)", 1000);
}else{
alert('Someting went wrong !');
}
}
}
全部代码:
<script type = "text/javascript">
var xmlHttp = createXmlHttpRequestObject();
function createXmlHttpRequestObject(){
var xmlHttp;
if(window.ActiveXObject){
try{
xmlHttp = new ActiveXObject("Microsoft.XMLHTTP");
}catch(e){
xmlHttp = false;
}
} else {
try{
xmlHttp = new XMLHttpRequest();
}catch(e){
xmlHttp = false;
}
}
if(!xmlHttp)
alert("Cant create that object !")
else
return xmlHttp;
}
function process(text){
//text = 'userInput';
if(xmlHttp.readyState==0 || xmlHttp.readyState==4){
food = encodeURIComponent(document.getElementById(text).value);
xmlHttp.open("GET", 'foodstore.php'+"?food="+food,true);
xmlHttp.onreadystatechange = function() {
handleServerResponse(text);
};
xmlHttp.send(null);
}else{
setTimeout("process(text)",1000);//cekaj 1s pa probaj opet
}
}
function handleServerResponse(text){
if(xmlHttp.readyState==4){
if(xmlHttp.status==200){
xmlResponse = xmlHttp.responseXML; //izvlaci se xml sto smo dobili
xmlDocumentElement = xmlResponse.documentElement;
message = xmlDocumentElement.firstChild.data;
document.getElementById('underInput').innerHTML = message;
setTimeout("process(text)", 1000);
}else{
alert('Someting went wrong !');
}
}
}
</script>
//*******************************************
<html>
<body onload = "process('userInput')">
<h3>The Chuff Bucker</h3>
Enter the food you would like to order:
<input type="text" id="userInput" />
<div id="underInput" />
</body>
</html>
尝试删除
中的“”setTimeout("process(text)", 1000);
[编辑以供参考] 而不是像这个
setTimeout(function(){
process(text);
}, 1000);
您的 AJAX 查询过于复杂了。您完全可以使用 JQUERY 吗?它的语法非常简单,而且易于实施,可能会解决您的问题。请看这个例子。
AJAX JQUERY
的语法var var_one = 'first post item here';
var var2 = $("#id_of_input_field").val();
///////// AJAX //////// AJAX //////////
$.ajax({
type: 'POST',
url: 'file_to_receive_post_vars.php',
data: {var_one:var_one, var2:var2},
success: function( response ){
alert('yay ajax!');
}//close succss params
});//close ajax
///////// AJAX //////// AJAX //////////
当您将字符串传递给 setTimeout
时,它会在全局范围内进行评估。没有全局 text
变量,所以调用会失败。而是传递一个函数:
setTimeout(function() {
process(text);
}, 1000);