- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有四个代表不同数据的饼图,使用 d3JS 库制作。它们制作正确,但是当我包含它们的图例时,上一个图表图例中的元素也会包含在下一个图表中。所以在最后一个图表的图例中,所有以前图表的图例元素都存在。
代码是这样的:
/*var divSkills, divKnows, divEnvs, divTools;
var dataSkills = [
{ label: 'Web Designing', count: 86 },
{ label: 'Web Development / Web Programming', count: 90 },
{ label: 'Graphic Designing / Logo Designing', count: 65 },
{ label: 'Programming', count: 73 },
{ label: 'Networking', count: 63 },
{ label: 'Content Writing', count: 56 }
];
var dataKnows = [
{ label: 'PHP', count: 75 },
{ label: 'SQL', count: 59 },
{ label: 'HTML 5', count: 90 },
{ label: 'CSS 3', count: 93 },
{ label: 'JavaScript', count: 80 },
{ label: 'C', count: 75 }
];
var dataEnvs = [
{ label: 'Adobe Dreamweaver', count: 75 },
{ label: 'SublimeText', count: 80 },
{ label: 'Notepad++', count: 80 },
{ label: 'Cloud9 (Online IDE)', count: 80 }
];
var dataTools = [
{ label: 'Adobe Photoshop', count: 65 },
{ label: 'Adobe Illustrator', count: 30 },
{ label: 'Adobe Fireworks', count: 50 },
{ label: 'AutoDesk Maya', count: 40 },
{ label: 'Git / GitHub / GitLab (Control Version System)', count: 70 }
];
var dataset = [dataSkills, dataKnows, dataEnvs, dataTools];
var width = 360;
var height = 360;
var radius = Math.min(width, height) / 2;
var color = d3.scale.category20b();
var legendRectSize = 18;
var legendSpacing = 4;
$(document).ready(function () {
divSkills = d3.select(".view-graph section:first-child .graph"),
divKnows = d3.select(".view-graph section:nth-child(2) .graph"),
divEnvs = d3.select(".view-graph section:nth-child(3) .graph"),
divTools = d3.select(".view-graph section:last-child .graph");
var divs = [divSkills, divKnows, divEnvs, divTools];
var arc = d3.svg.arc()
.outerRadius(radius);
var pie = d3.layout.pie()
.value(function(d) { return d.count; })
.sort(null);*/
for (var i = 0; i < divs.length; i++) {
var svg = divs[i]
.append('svg')
.attr('width', width)
.attr('height', height)
.append('g')
.attr('transform', 'translate(' + (width / 2) + ',' + (height / 2) + ')');
var path = svg.selectAll('path')
.data(pie( dataset[i]) )
.enter()
.append('path')
.attr('d', arc)
.attr('fill', function(d, i) {
return color(d.data.label);
});
var legend = svg.selectAll('.legend')
.data(color.domain())
.enter()
.append('g')
.attr('class', 'legend')
.attr('transform', function(d, j) {
var height = legendRectSize + legendSpacing;
var offset = height * color.domain().length / 2;
var horz = 15 * legendRectSize;
var vert = j * height - offset;
return 'translate(' + horz + ',' + vert + ')';
});
legend.append('rect')
.attr('width', legendRectSize)
.attr('height', legendRectSize)
.style('fill', color)
.style('stroke', color);
legend.append('text')
.attr('x', legendRectSize + legendSpacing)
.attr('y', legendRectSize - legendSpacing)
.text(function(d) { return d; });
}
});
如您所见,我正在使用 for
循环来避免重复。我试图通过对代码进行多种修改来修复它,但都没有奏效。这是一个Pen这个的。现在,我有两个问题:
大部分代码取自这个 tutorial .
编辑:注释掉不相关的代码。
最佳答案
您的问题是 color.domain()
上的数据绑定(bind)。当您在每次迭代中执行 color(d.data.label)
时,域会增长。扔一个
console.log(color.domain());
在构建每个图例之前。你会看到:
["Web Designing", "Web Development / Web Programming", "Graphic Designing / Logo Designing", "Programming", "Networking", "Content Writing"]
["Web Designing", "Web Development / Web Programming", "Graphic Designing / Logo Designing", "Programming", "Networking", "Content Writing", "PHP", "SQL", "HTML 5", "CSS 3", "JavaScript", "C"]
["Web Designing", "Web Development / Web Programming", "Graphic Designing / Logo Designing", "Programming", "Networking", "Content Writing", "PHP", "SQL", "HTML 5", "CSS 3", "JavaScript", "C", "Adobe Dreamweaver", "SublimeText", "Notepad++", "Cloud9 (Online IDE)"]
["Web Designing", "Web Development / Web Programming", "Graphic Designing / Logo Designing", "Programming", "Networking", "Content Writing", "PHP", "SQL", "HTML 5", "CSS 3", "JavaScript", "C", "Adobe Dreamweaver", "SublimeText", "Notepad++", "Cloud9 (Online IDE)", "Adobe Photoshop", "Adobe Illustrator", "Adobe Fireworks", "AutoDesk Maya", "Git / GitHub / GitLab (Control Version System)"]
一个简单的解决方法是将数据绑定(bind)到:
var pieLabels = dataset[i].map(function(d){
return d.label;
});
var legend = svg.selectAll('.legend')
.data(pieLabels);
关于javascript - D3JS 包括以前的图例元素,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33315927/
127.0.0.1:8000/api/仅包含来自第二个应用程序的 url,但我将两个 url 模块链接到相同的模式。甚至有可能做到这一点吗? 第一个应用程序: from django.urls imp
我目前正在学习 ColdFusion。我有 PHP 背景,对此我有点困惑。 我有一个选择菜单,我希望将选项保存在不同的文件中。 (例如 options.cfm)当我调用文件时,我想在选择菜单中包含选项
字符串: "75,000", "is", "95%", "or", "95/100" "of", "monthly", "income" o/p: "is","%, "or", "/", "of",
我有 4 个 javascript 文件(每个文件对应一个 HTML 文件),所有 4 个文件中的 3 个函数都是相同的。我想找到一个顺利的解决方案,我可以以某种方式分别包含这 3 个函数...是否可
我在 PHP 中有这种情况,其中 include在一台服务器上被遗漏,但在另一台服务器上没有(我没有设置服务器,所以我不能告诉你更多;我不是真正的 devops 人,所以这就是我在这里问的原因)。两台
这是一个模式文件,midi.xsd定义类型,note ,用于存储 MIDI 音符值: 这是另一个模式文件,octaves.xsd使用
我想备份以下文件夹 /home /etc /usr/local /root /var /boot 并排除 /var/tmp /var/run /var/lock /home/*/.thumbnails
如何重新编码具有许多值(包括缺失值)的数值变量,以获得数字 0:n-1哪里n是唯一值的数量,包括 NA ,整齐? 例子: df 1 1000 0 2 1000 0 3 N
选择元素的 html(包括在内)的最佳方法是什么?例如: This is just a test. 而$('#testDiv').html()返回"This is just a test."
我正在尝试设置Varnish来处理本地环境中的ESI包含。 我在虚拟机中运行 Varnish ,内容在主机上运行。 我有两个文件“index.html”和“test.html”。它们都存储在apach
我有以下内容,并且想要检索“ FromEmail”不为空的数据 Simple email@gma
欧海,我正在编写一个小型 PHP 应用程序,使用一个单独的 config.php 文件和一个functions.php,其中包含我将在应用程序中使用的所有自定义函数。现在,我真的必须在每个函数中包含
我知道可以将 JavaScript 放在一个特定的 .js 文件中,然后通过执行以下操作将其包含在任何页面中...... 我注意到,对于包含的这些 .js 文件: 它们实际上不必以 .js 结尾 其
我使用 gwt UIBinder 添加了一些项目到我的 ComboBox。 --select one-- Dispute Referral Form Dispute Settlement Clause
我可以将一个 first.c 文件包含到另一个 second.c 中吗? (我正在做一些套接字编程,以将服务器收到的消息存储在链接列表中,因此在第一个程序中,我尝试保留链接列表和第二个程序套接字编程文
我有一个简单的 Spring MVC 数据项目设置,我试图选择 Admin 中尚不存在的用户列表。 table 。这是我的存储库方法 SELECT u FROM User u WHERE u.id N
在 bash 脚本中,使用什么实用程序以及如何删除两个字符串之间的文本,包括字符串。 原文: (ABC blah1)blah 2(def blah 5)blah 7)(DEF blah 8)blah
我有这个 BST 问题,我试图用 Java 解决,但我不知道为什么它不起作用。问题是: 二叉搜索树 (BST) 是一种二叉树,其中每个值节点大于或等于该节点的所有节点中的值左子树并且小于该树中所有节点
我有一个字符串,其中包含“Dollars”和“Cents”符号。我想删除它们。我试过了 string.replaceAll("[\"\\u00A2\" $]", "") 但它不起作用。正确的做法是什么
我在 stories 和 tags 之间有一个多对多的关系,为保存关系而创建的表是 taxonomies。我想搜索所有具有所有给定标签的故事。 到目前为止我使用的查询是这个,当然它对我不起作用,它返回
我是一名优秀的程序员,十分优秀!