- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我正在创建一个简单的条形图并尝试让它响应用户的点击。单击的栏应该会消失。除了单击第一个栏会使末尾的栏消失外,一切似乎都正常。我完全不知道为什么会这样,非常感谢任何帮助。
Plunkr 上的完整代码:
https://plnkr.co/edit/H8K0ISdhGrb5HirrX2MG?p=preview
当用户点击栏时,我会调用更新函数。我创建了一个 removefromarray
函数来返回数据对象减去绑定(bind)到点击栏的数据。 :
d3.tsv("CantTouchThis.tsv",function(d,i){
d.FieldGoals = +d.FieldGoals;
return d;
}, function(error,data){
if (error) throw error;
y.domain([0,d3.max(data, function(d){return d.FieldGoals})]);
x.domain(data.map(function(d){return d.Player}));data used as the x attribute
function update(indx){
var selection = g.selectAll(".bars")
.data(data.removefromarray(indx), function(d){console.log('d');console.log(d); return d}) //printing d shows the previous bars and new bars are being returned, I suspect this may be causing the problem, but not sure
selection.enter().append("rect")
.attr("class","bars")
.attr("width",function(d){return x.bandwidth()})
.attr("x",function(d){return x(d.Player)})
.attr("height",function(d){return height - y(d.FieldGoals)})
.attr("y",function(d){return y(d.FieldGoals)})
.on("click",function(d,i){update(i);});
console.log(selection.enter())
console.log(selection.exit())
selection.exit().remove()
}
最佳答案
解决方案 1:您缺少“更新”选项:
selection.attr("width",function(d){return x.bandwidth()})
.attr("x",function(d){return x(d.Player)})
.attr("height",function(d){return height - y(d.FieldGoals)})
.attr("y",function(d){return y(d.FieldGoals)})
.on("click",function(d,i){update(i);});
这是您更新的插件:https://plnkr.co/edit/qJY5KgY9FBvuJ8krddYm?p=preview
解决方案 2:另一个非常简单的解决方案(正确地解决了您的问题,“为什么第一个柱状图不使用退出方法消失?”):在数据绑定(bind)选择中使用正确的键:
var selection = g.selectAll(".bars")
.data(data.removefromarray(indx), function(d){ return d.Player});
// this is the proper key function ---^
但是,请记住,此“解决方案”不适用于所有点击。发生这种情况是因为您删除数据对象的方法(在扩展原型(prototype)中使用 splice)未正常工作。
这是另一个更新的插件:https://plnkr.co/edit/rVTinxx45nmBvFiWwqgg?p=preview
PS:有更简单的方法来做你想做的事(也更适合 D3 代码)。
关于javascript - d3js : why doesn't first bar disappear using exit method?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/41371282/
所以我正在尝试制作一种命运之轮游戏或刽子手。我有 33 个代表字母的按钮,1 个按钮 = 1 个字母。当用户按下其中一个时,它必须“消失”(变得禁用和不可见)。我在 SceneBuilder 中创建了
我试图让 span 元素在悬停时消失。锻炼效果不佳。 代码:(CSS) .list-item-note { font-size:9px; color:#666; font-s
使用复选框,我想更改两个单选按钮的选中状态。这工作正常,但是当再次更改复选框时,单选按钮选中视觉“消失”,而代码显示它被选中。这是怎么来的? 演示:http://jsfiddle.net/Tz99c/
每当我只是在 Eclipse 中键入一些代码,并单击灰色带状区域上的错误灯泡时,我的代码就跑掉了,我必须关闭文件并重新打开它才能看到我的代码再次编码。有人可以帮我弄清楚如何停止吗?谢谢 最佳答案 我可
我有一个相当奇怪的问题,我无法找到相关文档。我有一个使用 Delphi 内置 TDBMemo 组件的 Delphi 程序,因为该组件需要从数据库中的字段中提取数据。用户还必须能够编辑此信息,即将信息添
我正在尝试使脚本基于输入文件返回AD用户ID,显示名称和组成员身份,并将结果导出到另一个文件。 但是,组成员身份信息似乎在此过程中丢失了。 有任何想法吗? 我当前的脚本: $Result = @()
我有一个背景 Pane ,用于绘制与 BorderPane、VBox 和 HBox 结合使用时不显示的对象。此外,我的 BorderPane 没有正确定位布局(左、下、右)。我尝试过使用多个不同的 P
我在使用自定义 ArrayAdapter 的 ListActivity 中使用我的 ListView 时遇到问题。 当 ListActivity 隐藏(暂停,无论怎样)时,ArrayAdpater 中
看看这张图片 左上角是 Android 汉堡包菜单,但它是白色的。另外,右边是一个搜索放大镜,也是白色的。问题是背景是根据呈现的内容从服务器动态加载的。 是否可以对菜单图标进行着色或提升它们,以便在出
我有一个有点愚蠢的问题。问题是我的程序必须具有从数据库中删除数据的功能。是的,这不是真正的问题。但是我怎样才能删除数据而不会有其他人看到某些内容已被删除的危险。 User Table: U_ID U
我正在编写一个原型(prototype),但遇到了 GUI 问题。我希望 JPanel pCustomer 居中,但这样做它会完全消失。例如,如果我把它放在南方,一切都很好。 import javax
我正在尝试重新创建一个类似于 App Store 故事页脚中使用的 UIVisualEffectView。虽然它看起来很简单,但我无法配置模糊以在白色背景下以相同方式响应。 开箱即用,带有 .ligh
我正在尝试使用 Python 和 SQLite 更新我的用户详细信息。 目的是一次升级我的用户的所有列。 我的代码是: def update(): new_username = input("In
我的工作与网络前端开发人员/websedigner 一样独立,而且我在 Android 手机上使用 HTML5 横幅广告。在 iOS 手机和平板电脑、Chrome 或 Safari 上,它运行完美。但
我以编程方式为我的 View 设置背景图像: UIImageView *backgroundView = [[UIImageView alloc] initWithImage:[UIImage im
假设我有一个这样定义的调试函数: namespace debug { void report(std::string message); } 我能否使用一些编译器技巧,在编译时将每个调用安全地
我在幻灯片中使用响应式断点。在小屏幕上,我一次显示一张幻灯片。在大 2 上(大意味着小于 990 像素) 示例:我将断点设置为在小屏幕上一次显示一张幻灯片,并在大屏幕上禁用 slider 。我有 8
我正在尝试用 Java 实现一个基本的物理引擎,并且使用 JOGL 绑定(bind),以便可以可视化结果。我可以轻松地创建和旋转形状,但在操作视口(viewport)和移动形状时遇到了问题。 我不认为
这个问题不太可能对任何 future 的访客有帮助;它只与一个较小的地理区域、一个特定的时间点或一个非常狭窄的情况相关,通常不适用于全世界的互联网受众。如需帮助使此问题更广泛适用,visit the
我有以下问题:我试图显示一个箭头,如果我从#colorSelect 中删除 overflow:hidden ,它就会起作用。但我需要 overflow:hidden 因为我里面有流元素。 我该如何解决
我是一名优秀的程序员,十分优秀!