Ajax.更新不能在ie8上工作

Ajax.Update doesn't work on IE 8

本文关键字:工作 ie8 更新 不能 Ajax      更新时间:2023-09-26

我有一个登录表单,用户可以在此表单上输入用户名/密码并单击登录按钮向服务器发送请求。

登录按钮调用一个名为submitLoginFormIntoDivAndReload的函数,而函数submitLoginFormIntoDivAndReload调用另一个名为submitFormObjIntoDivAndReload的函数。

下面是函数的详细信息:

function submitLoginFormIntoDivAndReload(servletUrl, formObj, divId) {
//var formObj = document.getElementById(formId);
var shortUserName = formObj.shortusername.value;
alert("starting userName: " + shortUserName);
var organization = formObj.organization.value;
alert("organization: " + organization);
formObj.username.value = createLdapString(shortUserName, organization);
alert("ending userName: " + formObj.username.value);
var loggingInContent = "<table><tr><td width='600px' align='center'><p>logging in</p></td></tr></table>"
document.getElementById(divId).innerHTML = loggingInContent;
submitFormObjIntoDivAndReload(servletUrl, formObj, divId);
}
function submitFormObjIntoDivAndReload(url, formObj, divId) {
alert('Form object: ' + formObj);
alert('url: ' + url);
alert('divId: '+divId);
var myRequest = new Ajax.Updater(divId, url,
        {   method: 'post',
            parameters: Form.serialize(formObj),
            onSuccess: function(reponse) {
                window.location.reload();
            }
        });
alert("after update");
}

这段代码在firefox上运行完美。但是,它不能在IE上工作。

在IE上,我可以获得所有警报(用于调试)。然而,似乎Ajax。Updater没有向服务器发送请求(我在服务器端看不到任何输出)。

在FireFox上,我也可以得到所有的修改。我可以看到Ajax。Updater确实向服务器发送请求,因为我可以在服务器端看到预期的输出。

我在网上搜索,有人说IE有缓存问题:Ajax更新程序在internet explorer中不工作但似乎这个问题只针对"GET"方法,而不针对"POST"方法。我使用的是"POST"方法。我还在表单中添加了一个假输入,它仍然不起作用。

有人知道吗?非常感谢!

顺便说一下,我使用的是原型1.5.1。

无论是POST还是GET,您的响应时间都将非常接近。我想说,您仍然遇到了在服务器响应之前持续存在的竞争条件。

我想看看这个关于防止竞态条件的链接。我找到的许多解决方案之一是"设置一个循环,每10毫秒检查一次值,否则等待。"