Jon*_*nez 4 javascript ajax jquery json
我正在尝试编写一个ajax Web应用程序.我有一个函数,假设请求一个json对象,然后使用它来重新/填充网站.
这是问题中的Javascript (第8 - 16行):
window.onload=LoadData("Home", {});
var _doc = {};
function LoadData(page, params) {
$.get(page, params, function ( data ) {
_doc = jQuery.parseJSON( data );
}
);
document.title = _doc.Title.Title;
};
Run Code Online (Sandbox Code Playgroud)
这是Chrome给出的错误:
Uncaught TypeError: Cannot read property 'Title' of undefined
LoadDatahttp://127.0.0.1/:15
(anonymous function)
Run Code Online (Sandbox Code Playgroud)
如果我在控制台中运行相同的语句,这让我感到困惑:
document.title = _doc.Title.Title;
"Home"
Run Code Online (Sandbox Code Playgroud)
它将标题更改为Home
这是证明其未定义:
_doc
Object
Body: Object
Menus: Array[4]
0: Object
Menu: Object
1: Object
Menu: Object
2: Object
Menu: Object
3: Object
Menu: Object
Title: Object
Title: "Home"
User: Object
Name: "Username"
Run Code Online (Sandbox Code Playgroud)
并截图作为概述:
注意:对底部函数的调用确实改变了标题
您只能data
在回调中访问AJAX请求:
window.onload=LoadData("Home", {});
var _doc = {};
function LoadData(page, params) {
$.get(page, params, function ( data ) {
_doc = jQuery.parseJSON( data );
document.title = _doc.Title.Title;
}
));
};
Run Code Online (Sandbox Code Playgroud)
AJAX请求(异步 JavaScript和XML)请求是异步的; 浏览器启动请求,而不是等待响应...而是继续执行JavaScript.一段时间后,当AJAX请求的HTTP请求完成时,将调用您为AJAX请求提供的回调,并且可以访问HTTP响应中包含的数据.
在你的情况下,在调度AJAX请求之后立即document.title = _doc.Title.Title;
执行(即在上面提到的一段时间之后发生); 所以回调还没有解决,所以仍然是一个空对象,所以是未定义的,并尝试在undefined 上检索是抛出错误._doc = jQuery.parseJSON( data );
_doc
_doc.Title
Title
_doc.Title
与您的问题无关,但仅供参考,您可能需要查看该jQuery.getJSON
方法; jQuery.get
方法之间的区别在于您传递的响应对象已经是JSON对象(因此您不需要调用jQuery.parseJSON
).
归档时间: |
|
查看次数: |
10779 次 |
最近记录: |