在做项目的时候,曾经遇到一个问题就是:使用$.getJSON获取数据的时候,在控制台打印的时候,能够看到数据中的responseJSON,但是获取不到这个数据,后来经过思考,明白原来是异步的原因,我们在控制台能够立即看到responseJONS数据是不错,但是这个数据的获取是异步获取,需要一定的时间,所以有了上篇提到的 $.getJSON的使用方法,很多初学者可能会忽视这个异步的问题(即使经常在脑海里提醒自己),会有疑问,为什么控制台打印出来的可以看到responseJSON,但是我却点(.)不出来呢?我们以下面的例子说明:
function getData(){
var json=$.getJSON("https://jsonplaceholder.typicode.com/users");
console.log('json',json);
}
我们在控制台调用调用这个函数后的结果:
想获得responseJSON的数据,有些初学者这会疑问 ,为什么明明看到了responseJSON,可是:console.log(json.responseJSON)却是undefined???(小盆友,你是不是有许多问号???);因为是异步,数据回来时需要时间的;改写一下:
setTimeout(()=>{console.log("%c json.responseJson","color:#909",json.responseJSON);},9000);
给你个时间,9秒之后我再来取数据,这样就可以得到数据了:
说明:讲解只是让一些小伙伴明白,数据请求的原理,获得数据的途径,参考上篇文章.