- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在学习 d3.js,最近我遇到了无法访问 d3.csv()
函数中的变量的问题。我刚刚在我的程序开始时初始化了我的变量,以使我的所有变量成为全局变量。
这让我想知道如果我将所有代码都放在 d3.csv
函数中是否会出现问题,甚至不需要在代码开头初始化我的变量,所以它看起来像:
d3.csv(data.csv, (data)=>{
all of my code
});
这样做有缺点吗(假设我只使用一个 CSV 文件)或者将不需要数据的代码保留在 d3.csv
方法之外是否有一些好处?
最佳答案
注意:由于您询问的是 d3.csv
的回调,我假设您使用的是 D3 v4 或更低版本,因为 D3 v5 使用 then
promise 的方法。然而,道理是一样的。
最重要的信息是 d3.csv
与所有其他 D3 XHR 方法一样,是一个异步函数。这意味着回调中的所有内容仅在 CSV 下载并解析后运行。
//Outside the callback
//Code here runs immediately
d3.csv("example.csv", (data) => {
//Inside the callback
//Code here runs only after the CSV was downloaded and parsed
});
//Outside the callback
//Even if these lines come after d3.csv, code here runs before the code inside the callback
顺便说一句,这解释了您最初的提示(“......我最近遇到了无法访问 d3.csv()
函数中的变量的问题”)。 This answer是关于该主题的好读物。
考虑到这一点,我们必须以这样一种方式优化代码,即可以立即创建/设置不依赖于数据的事物,因为如果我们将它们放在回调中,我们将浪费时间而没有任何好处原因。
简而言之,您可以将诸如(但不限于)这样的回调放在外面:
所有这些都不依赖于任何数据。对于其中一些(例如线生成器、区域生成器、堆栈生成器等...),您将在获得数据后传递数据。
然后,在回调中,放置所有依赖于数据的内容,例如(但不限于):
如您所见,如果将 everything 放入回调中,您将拥有一堆可以立即运行的方法,但它们只是坐在那里不必要地等待数据待下载。
关于javascript - 将我的所有代码放在 d3.csv() 的参数中是否有问题?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/56978213/
我当前项目中的许多类都有几个只能从类本身内部调用的属性和方法。此外,根据类(class)的当前状态,它们可能会扰乱类(class)的工作。 目前,所有这些接口(interface)都在 .h 文件的主
我想使用ngbTabSet将nav-pills in card-header 和tab-content in card-body。但我不知道该怎么做。 这是我尝试实现的示例(使用 bootstrap.
我正在浏览文档以查找如何允许放置在停靠栏图标上。据我所知,建议您使用 LSItemContentTypes,因为 CFBundleTypeOSTypes 已弃用。但是,我无法让 LSItemConte
我正在尝试在书签中使用 jquery UI 作为 slider 。并且 jquery ui 要求在普通 jquery 文件之后包含该文件。 所以到目前为止我所尝试的只是将脚本附加到 header ,同
您好,我尝试了广泛的谷歌搜索,但似乎没有任何帮助。 这是我的场景: 公司 Logo 存储在外部域/网址(矩形)中。 带有谷歌地图的 Ionic 应用程序,将这些 Logo 作为标记放置在 map 上。
我今天在阅读我的一些 C# 代码时发现了这一行: if (ProgenyList.ItemContainerGenerator.Status != System.Windows.Controls.Pr
我刚遇到this question在 Go FAQ 中,它让我想起了困扰我一段时间的事情。不幸的是,我真的不明白答案是什么。 似乎几乎所有非 C 类语言都将类型放在变量名之后,如下所示: var :
这是有效的 HTML 吗? 最佳答案 作为元素可以包含 phrasing content ,以及属于该组,则有效。 从语义上(并且具有一些常识),如果唯一的内容是 , 不;如果它同时包含文本和图像
这是有效的 HTML 吗? 最佳答案 作为元素可以包含 phrasing content ,以及属于该组,则有效。 从语义上(并且具有一些常识),如果唯一的内容是 , 不;如果它同时包含文本和图像
我有两本 T.Parr 写的关于 ANTLR 的书,我到处都看到美元符号和符号的引用。它也对我有用: term : IDENT -> { new TokenNode($IDENT) }; 或更复杂的东
我在实现段控制时遇到了一些问题。因为我希望它是一个固定的标题,所以当我滚动时我总是可以看到它,我已经在 - (UIView *)tableView:(UITableView *)tableView v
我有一个 20x36px (10x18pt) 的箭头图像,当我选择一个 UIImageView 时,将它拖到我的 View Controller 上然后设置图像,它总是模糊的。我只在我的项目中包含 @
How can I put background image when I hover a link Insert Bg in this a when hov
我需要在我的 .container 中添加(最新的第一个)新分区,但在 .controls (按钮)之后。可能吗? 注意:添加新的分区来保存按钮下方的前置控件对我来说不是一个选择。 HTML 需要保持
我是一名优秀的程序员,十分优秀!