- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我刚刚拿起 D3 并开始尝试条形图动画。我有 5 个小节,当我单击时会转换为 3 并返回。我可以:
对于如何获得两者的任何帮助,我们将不胜感激!完整文件在这里:
https://github.com/datapress/learningD3/blob/master/chart.html
var sortOrder = false;
d3.selectAll("rect")
.on("click", function() {
sortOrder = !sortOrder
var rectID = d3.select(this).attr("id");
var dataset0 = [1, 2, 3, 4, 5];
var dataset1 = [5, 1, 1];
var dataset2 = [1, 5, 1];
var dataset3 = [1, 1, 5];
var dataset4 = [5, 5, 1];
var dataset5 = [1, 5, 5];
if (sortOrder) {
if (rectID == 0) { dataset = dataset1 };
if (rectID == 1) { dataset = dataset2 };
if (rectID == 2) { dataset = dataset3 };
if (rectID == 3) { dataset = dataset4 };
if (rectID == 4) { dataset = dataset5 };
} else {
dataset = dataset0
}
xScale.domain(d3.range(dataset.length))
yScale.domain([0, d3.max(dataset, function(d) { return d; })])
svg.selectAll("rect")
.data(dataset)
.exit()
.remove()
svg.selectAll("rect")
.data(dataset)
.enter()
.append("rect")
.transition()
.duration(1000)
.attr({
x: function(d, i) { return xScale(i); },
y: function(d) { return h - yScale(d); },
width: xScale.rangeBand(),
height: function(d) { return yScale(d); },
fill: function(d) { return "rgb(0, 0, " + (255 - Math.round(d) * 36) + ")"; }
});
});
最佳答案
这很直率,但这里是您的代码已修复以更新两者:
http://jsfiddle.net/TheMcMurder/r0ptsfLr/
注意:您没有遵循 d3 的输入、更新、退出方法。您可以进入和退出,但是对于页面上存在但需要使用新数据进行更改的栏,您没有在任何地方进行隐式更新。
这是一个简化的示例:
var data =[45, 10]
var data2 =[45, 10, 20, 25, 30, 45]
/*The purpose of this JSfiddle is to show how enter, update, and exit works in d3js. The data values above are the data. The image had three manually created black circles. My update will resize them to the appropriate size (based on data) and change their color to blue. All newly drawn objects will be turned green and any object that is exiting will be turned red.
The transitions are delayed to make it easier to see. No delay is needed for this to work.
*/
//creating the svg so I can draw objects on it
var svg = d3.select("body").append("svg")
.attr("width", 500)
.attr("height", 5000)
//creating initial circle objects
var circle1 = svg.append("circle")
.attr("cx", 100)
.attr("cy", 100)
.attr("r", 25)
// another circle object
var circle2 = svg.append("circle")
.attr("cx", 100)
.attr("cy", 200)
.attr("r", 25)
// another circle object
var circle3 = svg.append("circle")
.attr("cx", 100)
.attr("cy", 300)
.attr("r", 25)
setTimeout( function(){
enter_update_exit(data)
}, 2500 )
setTimeout( function(){
enter_update_exit(data2)
}, 10000 )
setTimeout( function(){
enter_update_exit(data)
}, 15000 )
function enter_update_exit (data){
var circle_array = svg.selectAll("circle")
.data(data);
//**********************************************************************************
// Enter: all pieces of data that do not have a node to bind to. In this case where
// there are already three circles ('nodes') there would have to be more than 3
// data points in our dataset to have enter run at all;
//**********************************************************************************
circle_array.enter()
.append("circle")
.attr("cx", 100)
.attr("cy", function(d, i){
return (i + 1)*100
})
.attr("r", 0)
.attr("fill", "#78AB46")
.transition()
.duration(1500)
.attr("r", function (d){return d;});
//**********************************************************************************
// Update: Every node that is bound to data, in this case that is everything we've
// entered and everything that has just been bound from the .data(data) bind.
//**********************************************************************************
circle_array.transition()
.duration(1500)
.delay(1500)
.style('fill', 'steelblue')
.attr('r', function (d){
return d;
});
//**********************************************************************************
// Exit: Every node ('circles') that exists in your selection that you don't have
// bound data to
//**********************************************************************************
circle_array.exit()
.transition().duration(1500).delay(1500)
.style("fill", "red")
.transition().duration(1500).delay(3000)
.attr("r", 0).transition().remove();
}
http://jsfiddle.net/TheMcMurder/H3HTe/
希望对您有所帮助!
关于javascript - D3 图表过渡要么获得正确的数量或宽度,但不能同时获得正确的数量或宽度,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/28934702/
我的理解是 width: 100% 让元素的宽度与其父元素的宽度相同,而 width: inherit 只有在明确指定父元素的宽度时才这样做.这种理解是否正确? 如果是这样,在我看来,当 width:
并设置“高度”为全屏的 1/2。 这是我的代码: div{ background:red; } 最佳答案 我会结合使用 css 和 javascript(使
编辑 2: 问题似乎出在规则的“bigTable”元素上。显然,在布局模板上使用时继承了错误的最小宽度。我仍在调查此事。 不过,我将再尝试一次 div。一个大问题是使用固定导航和动态内容,但我已经为此
我的网站需要显示宽表。在它上面是标题,它应该和整个页面一样宽(在这种情况下,和表格一样宽)。但是,它的宽度与视口(viewport)(屏幕尺寸)一样宽,因此显示时看起来还不错,但是一旦用户滚动到侧面,
我有一个小问题。我总是使用 float 来安排我的元素。我正在转向 flexbox,我做了一些例子,一切都很好,但我正在做一个事情进展不顺利的例子。 我有一个包含 1 到 12 种产品的容器,每行 4
例如,它们在自动边距方面会导致完全不同的行为。 看看这个 fiddle :https://jsfiddle.net/L1rk46xy/ .fixed { display:fixed;
我尝试在帖子中将段落的宽度设置为 75%,并将图像的响应宽度设置为 100%。然而,总是在 默认。 Some texts Some texts Some texts Some texts 目前,我只
HTML 元素可以有 width/height 属性,也可以有 CSS width/height 属性: HTML 属性和 CSS 属性有什么区别,它们应该具有相同的效果吗? 最佳答案 有关该主题的
我有一个流动的 table ,现在需要一个固定的 thead。问题是当你固定 thead 时,th-s 不尊重 tbody 的 td-s 的宽度。列的大小都由 BootStrap 处理。我已经阅读了很
我想像这样布置一个区域: ---- ---- |A | |B | | | | | ---- ---- --------- |C | --------- 三个盒子中的每一个都是 .盒子
我遇到了很多问题。 1) 我正在使用 Bootstrap-Select 来获得具有搜索功能的现代选择框,但无论我尝试什么,我似乎都无法获得填充 col-span 的选择。 2) 我已将该行拆分为 2
http://jsfiddle.net/95EtZ/1/ 问题在行动中解决了一半。 现在它是用 javascript 中硬编码的容器宽度设置的。 我需要 js 来获取容器 div 的宽度——使用窗口滚
我想要两个宽度和高度均为 100% 的 div。我知道子 div 不会工作,因为父 div 没有特定的高度,但有没有办法解决这个问题? HTML: CSS: body
我需要使用 jQuery 更改 的高度和宽度 我尝试了以下代码 jQuery('#chart_popup').css('height','600px'); jQuery('#chart_popup')
在自定义 WPF 控件中,我想将控件的宽度设置为高度的函数。例如:Width = Height/3 * x; 实现此目的的最佳方法是什么,以便控件正确且流畅地调整大小(和初始大小)? 最佳答案 您可以
我正在使用igraph在R中绘制图形,执行plot(mygraph, vertex.color = "green")之类的操作。 有没有办法改变顶点边界的颜色和/或宽度? 最佳答案 查看下面的代码;
有没有办法使用jquery设置图像的高度和宽度?以下是我的代码 var img = new Image(); // Create image $(img).load(function(){
这个问题类似于 how-to-find-the-actual-width-of-grid-component-with-scrollbar-in-delphi 但我无法获取 CalcDrawInfo(
这里是 HTML/CSS 新手。 试图将我在 Codeacademy 上学到的知识付诸实践,但我遇到了一个问题,即我设置为 width:100% 的 header 最终离开了页面。我相信这是因为边框,
这里是 HTML/CSS 新手。 试图将我在 Codeacademy 上学到的知识付诸实践,但我遇到了一个问题,即我设置为 width:100% 的 header 最终离开了页面。我相信这是因为边框,
我是一名优秀的程序员,十分优秀!