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

 是唐雨冰吗 发布于 2023-02-07 13:20

我正在使用dc.js(http://edouard-legoupil.github.io/3W-Dashboard/)处理dataviz

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

dc.js已经是"dc.redrawAll();" 重置所有过滤器但是有没有能力冻结某个过滤器状态并将其传递给#href?

理想情况下,这样的href将通过共享按钮或通过常规的facebook/twitter共享功能共享.

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

先谢谢,爱德华

1 个回答
  • 以下是您要使用的关键方法:

    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示例.

    2023-02-07 13:22 回答
撰写答案
今天,你开发时遇到什么问题呢?
立即提问
热门标签
PHP1.CN | 中国最专业的PHP中文社区 | PNG素材下载 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有