我想使用以下代码获取全局变量中的数据:
var data;
d3.json ( "file.json" , function(json) {
data = json;
console.log(data); //defined
});
console.log(data); //undefined
但问题是我只是在 d3.json 函数中定义了数据变量,但它是未定义的。我该如何解决这个问题?
谢谢
我想使用以下代码获取全局变量中的数据:
var data;
d3.json ( "file.json" , function(json) {
data = json;
console.log(data); //defined
});
console.log(data); //undefined
但问题是我只是在 d3.json 函数中定义了数据变量,但它是未定义的。我该如何解决这个问题?
谢谢
由于 d3 请求(如d3.json
)是异步的,因此最佳做法是将依赖于外部请求的所有代码包装在请求回调中,确保此代码在执行之前可以访问数据。来自 D3 文档:“当异步加载数据时,依赖于加载数据的代码通常应该存在于回调函数中。”
因此,一种选择是将所有代码放在回调函数中。如果您想将代码分成几部分,您还可以将请求的响应传递给一个单独的函数,如下所示:
function myFunc(data) {
console.log(data);
}
d3.json('file.json', function (data) {
var json = data;
myFunc(json);
});