发布网友 发布时间:2022-04-23 23:46
共5个回答
热心网友 时间:2022-04-23 01:42
ajax 返回后 用户数字签名会丢失照成无法调用其他js函数所以 应该是不能用一个方法实现 除非是settimeout 可以这样判断 ajax之后把获取的数据 放到一个隐藏的input里面 然后 用一个settimeout (function,1000*60) 调用一个function 这个function执行的是 判断隐藏input里面的内容如果为空那么就调用ajax请求,不为空就不执行。
前面是给你说的逻辑 下面是步骤
1、页面放一个隐藏的input <div style="display:none"><input type="text"value="" class="hdinput"></div>或者其他
2、js里面加上一个function 执行
function (){
if(document.getElementByClass("hdinput")[0].value==null||document.getElementByClass("hdinput")[0].value=="")
{//执行你调用ajax请求的那个方法}
}
ajax返回判断为空 给赋值为"" 不为空赋值为其他 就OK了
热心网友 时间:2022-04-23 03:00
你可以在ajax中使用setTimeout()或者setInterval()方法。
setTimeout指的是定时调用code,不过只执行一次,想要再次执行需要重新调用
setInterval与setTimeout类似,区别是他会一直调用,直到手动停止
让他们停止的方法分别是clearTiomeout和clearInterval,
这两个方法你可以搜一下用法,
你这个使用setTimeout会很符合一般人的逻辑,在ajax返回的时候判断是否为空,为空则调用,不为空不调用即可
热心网友 时间:2022-04-23 04:35
ajax设置超时1分钟,
complete的时候判断超时,如果超时,重调一次funa
success的时候判断结果,没有结果的时候,重调一次funa
success有结果的时候,处理结果即可。
热心网友 时间:2022-04-23 06:26
// 设置timeout
function send () {
$.jquery('url', {
timeout: 60000,
success: function () {
// 成功
},
error: function (o, e) {
if (e == 'timeout') {
// 超时了,重新发送
send();
}
}
});
}
send();
热心网友 时间:2022-04-23 08:34
while(Xhr.readyState != 4){
var time1 = 获取当前时间;//我不知道怎么获取当前时间
var time2;
while(true){
time2 = 获取当前时间;
if(time2 - time1 == 1分钟){ //如果是格林威治时间1分钟这里写60*1000
break;
}
}
Xhr.send(null);
}追问我是用jquery里的ajax,不知道怎么改,能再帮我贴一段更详细的代码吗?谢谢!
追答var userXhr = getXhr();
userXhr.open("POST", "find?ad=" + ad + "&sid=" + Math.random(), true);
userXhr.onreadystatechange = function() {
代码区
if (userXhr.readyState == 4) {
var r = userXhr.responseText;
if (r === "F") {
} else {
}
}
};
userXhr.send(null);
我基本上不用jquery,更不知道jquery有封装过ajax,上面是ajax的基本结构,send方法表示开始发送请求,如果你理解ajax的结构,你只需要把我第一次回答的那段代码放到 代码区 就可以实现1分钟重后新发送