我想从服务器获取一些数据并将其写入 JavaScript 中的全局数组。然后在准备好的文档中,我想使用这个数组来创建一些新元素(选项)。我应该有这个数据的全局数组,因为在第一次加载后客户端可以使用这个数据修改用户界面。
$(document).ready(function () {
UseAjaxQueryForFillGlobalArray();
MakingInterfaceUsingGlobalArray();
});
但是我有奇怪的行为,当我调试页面时,我可以看到该方法MakingInterfaceUsingGlobalArray首先工作,并且在我通过 AJAX 使用UseAjaxQueryForFillGlobalArray方法获取数据并且我没有加载数据的新接口(html 选项)之后。
如果我这样做:
UseAjaxQueryForFillGlobalArray();
$(document).ready(function () {
MakingInterfaceUsingGlobalArray();
});
然后在 Firefox 中工作正常,但在另一个网络浏览器中第一次加载不正确(例如通过链接转到此页面)。但是如果我按 F5 刷新,我有正确的用户界面,它通过 AJAX 加载到全局 JS 数组。
如何解决?也许我使用了完全不正确的方式?
在评论后添加:
这是我的 ajax 函数:
function UseAjaxQueryForFillGlobalArray(){
var curUserId = '<%= Master.CurrentUserDetails.Id %>';
var curLocale = '<%= Master.CurrentLocale %>';
$.ajax({
type: "POST",
url: "/segment.aspx/GetArrayForCF",
data: '{"userId":"' + curUserId + '","curLocale":"' + curLocale + '"}',
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (msg) {
//here is I doing parse my string from server and fill arrays.
}
});
}