var a = 0;
someAsyncProcess(function callback() { a = 1; });
console.log(a);
// → 0
實際上等價於
var a = 0;
var callback = function callback() { a = 1; }; // no immediate invocation here
console.log(a);
// → 0
// ... After a period of time ...
callback();
// `a === 1` now.
你这样写肯定是得不到的,因为ajax是异步的,也就是后面的代码会先执行,所以为"";
至于把ajax的async改为false,这个我也不清楚,你可以断点调试一下,在这两块地方都打上断点,看谁先执行,顺便通过调试还可以看看jQuery的ajax的工作原理。^_^
如果你清楚js的执行方式和异步之间的区别,就知道为什么了。
因为js是顺序加载的,当执行到ajax部分的时候,ajax执行的时候,ajax下面的代码是会在ajax执行的同时执行到的。
這種問題已然成爲日經貼了
實際上等價於
这里有说明
如果需要发送同步请求,请将此选项设置为 false 。跨域请求和 dataType: "jsonp" 请求不支持同步操作。
贴代码看下,应该是个语法错误而已
我觉得这样写还是不太好 最好还是把处理函数写在回调里吧
@Go_Geek 他的才是正解。你试试把Ajax拿到的数据用来在Ajax里调用处理这个数据的函数试试。 至于原因,貌似是闭包什么的,貌似。
jsonp是不支持sync:false的,打上去也还是异步请求。所以请求还没回来就已经开始赋值""了,赋值还是得写到success里面的。