- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我在下面有一个构建条形图的脚本,但我需要从我的数组中提取数据点,数组数据始终是随机的,用户可以选择他们想要的数据作为 x 轴以及哪些数据将是y 轴。
var myArray = ["Month,Expenditure,Income,Year", "January,187458,297664,1","February,104967,274354,1","March,202394,343509,1","April,187532,94652,1","May,138745,206456,1","June,234857,143657,1","July,193453,203433,1","August,96343,45064,1","September,371298,505635,1","October,63756,85635,1", "November,45363,14355,1", "December,98642,173125,1"];
var chart = new CanvasJS.Chart("chartContainer", {
animationEnabled: true,
theme: "light2",
title:{
text: title.value
},
axisY: {
title: yaxis.value
},
data: [{
type: "column",
dataPoints: [
{ y: , label: },
]
}]
});
chart.render();
}
因此,如果用户选择 yaxis 作为支出,xaxis 作为月份,数据点将构建为 { y: 18458, label: January},并且将重复直到这些标题下的所有数据都被使用。
我正在尝试找出执行此操作的最佳方法,我已经制作了下拉列表来声明他们在 x 轴和 y 轴内想要的值。通过这个调用名称;
var xaxis = document.getElementsByName('xaxis')[0];
var yaxis = document.getElementsByName('yaxis')[0];
最佳答案
好的,当您使用 CanvasJS 图表时,只需编写一些代码来根据用户选择更新您的图表。
这是如何在 CanvasJS https://canvasjs.com/docs/charts/basics-of-creating-html5-chart/working-with-data/ 中处理数据的文档
我想每次用户选择轴时,您都需要检查是否选择了两个轴,如果是 - 重新渲染图表。
function updateChart() {
let newData = [];
myArray.forEach(function(dataEl) {
// update newData with each data element
});
chart.options.data[0].dataPoints = newData;
}
您还需要更改图表选项,例如 axisY
选项
最后就是阅读 CanvasJS 文档并根据自己的需求更新图表数据。
更新:
正因为你问了,这里是你的代码(当心月份在 Y 轴上,但我已经为此添加了处理 - 将图表类型切换为“条形图”)
var myArray = ["Month,Expenditure,Income,Year", "January,187458,297664,1",
"February,104967,274354,1", "March,202394,343509,1", "April,187532,94652,1",
"May,138745,206456,1", "June,234857,143657,1", "July,193453,203433,1",
"August,96343,45064,1", "September,371298,505635,1",
"October,63756,85635,1", "November,45363,14355,1",
"December,98642,173125,1"];
const select1 = document.querySelector('select[name=xaxis]');
const select2 = document.querySelector('select[name=yaxis]');
myArray[0].split(',').forEach(item => {
select1.appendChild(document.createElement('option')).textContent = item;
select2.appendChild(document.createElement('option')).textContent = item;
});
function generateBar() {
var title = document.getElementById("chartTitle");
var xaxis = document.getElementsByName('xaxis')[0];
var yaxis = document.getElementsByName('yaxis')[0];
let type = 'column';
let xaxisVal = xaxis.value;
let yaxisVal = yaxis.value;
if (yaxisVal === "Month") {
type = 'bar'; // for this case bar type
xaxisVal = yaxis.value;
yaxisVal = xaxis.value; // Y cannot be non-integer
}
let columns = myArray[0].split(',');
var dataPoints = myArray.slice(1).map((el) => {
let dataParts = el.split(',');
return {
y: parseInt(dataParts[columns.indexOf(yaxisVal)]),
label: dataParts[columns.indexOf(xaxisVal)]
}
});
var chart = new CanvasJS.Chart("chartContainer", {
animationEnabled: true,
theme: "light2", // "light1", "light2", "dark1", "dark2",
title:{
text: title.value
},
axisY: {
title: yaxis.value
},
data: [{
type: type,
dataPoints: dataPoints
}]
});
chart.render();
}
<!DOCTYPE html>
<html>
<body>
<table>
<p>X-Axis Data</p><p><select name="xaxis">
</select></p><p>Y-Axis Data</p><p><select name="yaxis"></select></p>
<p>Create a Title for Your Chart</p><input type="text" id="chartTitle"><p>
<button onclick="generateBar()">Generate Chart</p>
</table>
<div id="chartContainer" style="height: 100%; width: 100%;"></div>
</body>
<script src="https://canvasjs.com/assets/script/canvasjs.min.js"></script>
</html>
关于Javascript 从数组中选择数据以创建供图表使用的集合列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49484436/
大家好我有一个应用程序可以打开一个包含文本和图像组合的文章的 WebView 。如您所知,文章有不同的字体,我想知道是否有办法让 Web View 呈现几种 Helvetica 字体,就像在安装了这些
我正在寻找一种好的格式来归档旧 Linux 计算机的整个文件系统。 西藏自治区 tar.gz 格式非常适合归档具有 UNIX 样式属性的文件,但由于压缩应用于整个归档,因此设计排除了随机访问。相反,如
我最近一直在苦苦挣扎,因为我不得不更改我不久前编写的一些代码以在 Qt 中进行图像处理和 OpenGl以支持多线程。 问题是我想用它在一组图像上应用批量过滤器, 我正在使用 openMP 来做这样的多
我已成功将两个实际设备连接到 Azure IoTHub(在同一个 IoT 中心),并希望第二个设备接收第一个设备发送的消息。因此,在普通的 MQTT 代理中,第二个设备仅订阅该主题,但 Azure没有
我需要一些 Jenkins 作业才能通过 ssh 通过 shell 命令行访问其他一些机器。 我该怎么做? 我没有目标服务器的密码,但我有一个“ key ”文件,但是当我使用以下命令运行作业时 ssh
我在 Mac OSX Mavericks 上使用 MAMP。我想安装最新的 XDebug v2.2.4。根据 XDebug 向导,我下载了 XDebug 2.2.4 源代码。我的系统上安装了许多版本的
所以我正在制作一个程序,从用户给定的 AZ Lyrics 歌曲中提取歌词。我遇到的问题是,在将字符串转换为 URL 后,它说 Jsoup 无法解析它,因为它不接受字符串,尽管变量是我们传入的 URL。
我已经安装了 AWS .NET SDK通过 MSI 安装程序。我想使用这段代码: static IAmazonS3 client; client = new AmazonS3Client(Amazon
我正在使用 cURL 检索另一个页面,除非我有特定的 cookie,否则我看不到页面内容。 cookie 名称是 seepage,它的值必须设置为 1 才能让我看到页面内容。 我想使用 cURL 加载
目录 1、VLC代码封装 1.1 QT(C++)工程 1.2static 声明 m_instance 优化效率 1.3封装 DLL
我是 Docker 新手,但有一个 Java Web 应用程序项目,我的 Maven 构建会为其生成并安装 Docker 镜像。即 mvn clean install 产品: REPOSITORY
我正在尝试在 Debian Stretch 上做一个带有 uinput 的虚拟键盘,我可以输入字符串,比如“Toto!”,键盘会写入这个字符串。但是,我一直坚持从 C char 到键盘处理的键码的转换
我们正在 Rails 中开发一个 JSON REST API,供我们也在开发的 Android 应用程序使用。有什么方法可以保护 API,使其只能由我们特定的 Android 应用程序使用? API
关闭。这个问题需要debugging details .它目前不接受答案。 编辑问题以包含 desired behavior, a specific problem or error, and th
所以我有一个问题,我有 2 个应用程序部署在具有不同端口的同一网站上,一个是登录应用程序,一个是HRIS 系统。 我的问题是,当我的登录应用程序创建 token 时并重定向到我的 hris 系统,hr
在给出的第三段代码的上下文中交谈 on this page , 有一个方法 Messenger named getBinder()返回 the IBinder Messenger 用于与 associ
我目前有一个私有(private) Java 项目,我正在尝试将其完善以供其他开发人员使用。我想做的一件事是让 Ant 自己下载 JUnit、PMD 和 FindBugs 等所需的 JAR,这样开发人
我想在 Qt 中使用 ffmpeg 库进行编程。 如何在 Windows 上将 ffmpeg 编译成 *.lib 文件? 或 如何使用Qt官方发布的编译后的*.dll文件? 还有,哪种方式比较好? 最
我正在为扩展 std::vector 实例化的 C++ 类开发 Python 绑定(bind)。为了让 Python 下标运算符为此类工作,我添加了如下所示的 __getitem__ 函数(我删除了不
我正在为 Amazon SWF 的相当简单的工作流程编写 PHP。我发现自己开始编写一个库来检查某些操作是否已经开始或完成。基本上遍历事件列表以检查事情的进展情况,然后在需要时启动适当的事件。有时这可
我是一名优秀的程序员,十分优秀!