标签:getjson javascript jquery json
这是我的代码:
var source;
source = $.getJSON(url, function(json) {
return console.log(json);
});
以上是返回完整的jQuery对象与我请求的JSON.响应看起来像这样:
abort: function ( statusText ) {
always: function () {
complete: function () {
done: function () {
error: function () {
fail: function () {
getAllResponseHeaders: function () {
getResponseHeader: function ( key ) {
isRejected: function () {
isResolved: function () {
overrideMimeType: function ( type ) {
pipe: function ( fnDone, fnFail ) {
promise: function ( obj ) {
readyState: 4
responseText: "{'Hello':'World'}"
setRequestHeader: function ( name, value ) {
status: 200
statusCode: function ( map ) {
statusText: "OK"
success: function () {
then: function ( doneCallbacks, failCallbacks ) {
__proto__: Object
谁知道我做错了什么?我一直在处理这个问题几个小时:(
解决方法:
AJAX是异步的,源不能与您请求的JSON相等,因为它尚不可用. jQuery.getJSON将返回它创建的jqXHR对象来处理请求,然后运行并检索响应.
$.getJSON(url, function(json) {
// deal with response here
});
在响应可用(稍后一段时间)后,将执行回调(您正在传递的函数),因此您可以通过第一个参数(您称为json)访问响应.
你可以通过尝试以下方法看到这一点:
console.log('1');
$.getJSON(url, function(json) {
console.log('2');
});
console.log('3');
您将看到您的控制台将读取1,3,然后在一瞬间读取(即执行HTTP请求的时间),2;这显示getJSON响应在没有完成的情况下返回,脚本继续执行,然后在一段时间后调用回调.
标签:getjson,javascript,jquery,json 来源: https://codeday.me/bug/20190826/1733039.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。