在某些情况下,我被迫在会话中保留页面设置(Javascript值),并且必须在离开页面之前完成(我不能使用cookies,因为"pageSettings“可能会变得非常大,而localStorage还不是一个选项;)。所以这就是我尝试的方式。然而,当我再次直接调用页面时,"http://blabla.com/bla“的调用似乎是异步的,即使设置了async-attribute (我没有收到上一次调用的设置,而是前一次调用的设置):
$jQ(document).ready(function () {
$jQ(window).unload(Main.__setSessionValues);
});
var Main = {
pageSettings: {},
__setSessionValues: function __setSessionValues() {
$jQ.ajax({
type: "POST",
async: false,
url: "http://blabla.com/bla",
data: {
pageSettings: Object.toJSON(Main.pageSettings)
}
});
}
};有人知道问题出在哪里吗?
提前感谢
发布于 2010-06-14 15:31:42
代码看起来没问题。您可能会尝试使用bind('beforeunload', ...)而不是unload,以便尽早获取内容。当然,如果有其他东西也挂上了beforeunload,卸载被取消了,那么即使您还在页面上,您的调用也会被发出。
有点离题,但如果你能找到一种不同的方法,我会的。当用户试图离开页面时触发同步ajax调用是不理想的。
https://stackoverflow.com/questions/3035573
复制相似问题