gpt4 book ai didi

javascript - dc.js 永久链接或 href 共享可视化过滤器状态?

转载 作者:数据小太阳 更新时间:2023-10-29 05:05:55 24 4
gpt4 key购买 nike

我正在使用 dc.js ( http://edouard-legoupil.github.io/3W-Dashboard/ ) 开发数据可视化

主要限制是,当用户在探索数据时发现特定事实时,要重现他们使用的确切过滤器以便与其他用户分享他们的发现(并发起讨论)并不容易。一个解决方案可能是为每个过滤器状态设置永久链接。

dc.js 已经有了“dc.redrawAll();”重置所有过滤器,但是否有能力卡住某个过滤器状态并将其传递给#href?

理想情况下,此类 href 将通过分享按钮或通过常规的 facebook/twitter 分享功能分享。

任何代码片段或示例都会很有帮助!

提前致谢,爱德华

最佳答案

以下是您将要使用的关键方法:

  • dc.chartRegistry.list():检索 dc 已加载的所有图表的数组
  • chart.filters():检索给定图表的所有过滤器的数组
  • chart.filter():对给定图表应用过滤器
  • dc.redrawAll():在应用外部过滤器后重绘所有图表

从那里开始,只需要对对象进行序列化和反序列化。

这是一种通过字符串化 JSON 对象来实现的方法:

var filters = [];
for (var i = 0; i < dc.chartRegistry.list().length; i++) {
var chart = dc.chartRegistry.list()[i];
for (var j = 0; j < chart.filters().length; j++){
filters.push({ChartID: chart.chartID(), Filter: chart.filters()[j]});
}
}
var urlParam = encodeURIComponent(JSON.stringify(filters));

这是解析 JSON 字符串并应用过滤器的逆向过程:

var urlParam = ""; //have user input string somehow
var filterObjects = JSON.parse(decodeURIComponent(urlParam));
for (var i = 0; i< filterObjects.length; i++)
{
dc.chartRegistry.list()[filterObjects[i].ChartID-1].filter(filterObjects[i].Filter);
}
dc.redrawAll();

连接这两个步骤将取决于您的场景。您也许可以将字符串保存到数据库中或将其附加为 url 参数。

此代码可能缺少一些边缘情况,但它似乎适用于基本的 dc.js 示例。

关于javascript - dc.js 永久链接或 href 共享可视化过滤器状态?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/20853794/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com