use*_*607 6 javascript permalinks href crossfilter dc.js
我正在使用dc.js(http://edouard-legoupil.github.io/3W-Dashboard/)处理dataviz
主要限制是,当用户在探索数据时发现特定事实时,要重现他们使用的确切过滤器以便与其他用户共享他们的发现(并启动讨论)并不容易.解决方案可能是为每个过滤器状态设置永久链接.
dc.js已经是"dc.redrawAll();" 重置所有过滤器但是有没有能力冻结某个过滤器状态并将其传递给#href?
理想情况下,这样的href将通过共享按钮或通过常规的facebook/twitter共享功能共享.
任何代码段或示例都会有所帮助!
先谢谢,爱德华
DJ *_*tin 11
以下是您要使用的关键方法:
从那里它只是序列化和反序列化对象的问题.
这是通过字符串化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));
Run Code Online (Sandbox Code Playgroud)
以下是解析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();
Run Code Online (Sandbox Code Playgroud)
连接这两个步骤取决于您的方案.您也许可以将字符串保存到数据库或将其作为url参数附加.
这段代码可能缺少一些边缘情况,但它似乎适用于基本的dc.js示例.
| 归档时间: |
|
| 查看次数: |
1374 次 |
| 最近记录: |