首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在每次引入数据中的元素时动态创建新的div

如何在每次引入数据中的元素时动态创建新的div
EN

Stack Overflow用户
提问于 2015-10-20 09:05:18
回答 1查看 242关注 0票数 2

我有一个来自有几个块设备的VM的数据。每个块设备都用一个行图来表示,它使用c3.js创建,在数据集中读取Bytes_Read和Bytes_Written,并实时绘制。但是,当dataset中引入了新的块设备时,我正在努力解决这个问题,它不会创建一个新的图表。使用JavaScript实现这一目标的最佳方法是什么。

我的数据集样本

代码语言:javascript
复制
    {
        "devices": [
            {
                "Name": "bdev0",
                "output": {
                    "IO_Operations": 0,
                    "Bytes_Read": 0,
                    "Bytes_Written": 0
                }
            },
{
                "Name": "bdev0",
                "output": {
                    "IO_Operations": 1,
                    "Bytes_Read": 2,
                    "Bytes_Written": 3
                }
            },
{
                "Name": "bdev0",
                "output": {
                    "IO_Operations": 5,
                    "Bytes_Read": 7,
                    "Bytes_Written": 8
                }
            },
            {
                "Name": "bdev1",
                "output": {
                    "IO_Operations": 10,
                    "Bytes_Read": 20,
                    "Bytes_Written": 30
                }
            }
        ]
    }

使用新设备更新的数据集

代码语言:javascript
复制
    {
        "devices": [
            {
                "Name": "bdev0",
                "output": {
                    "IO_Operations": 0,
                    "Bytes_Read": 0,
                    "Bytes_Written": 0
                }
            },
{
                "Name": "bdev0",
                "output": {
                    "IO_Operations": 1,
                    "Bytes_Read": 2,
                    "Bytes_Written": 3
                }
            },
{
                "Name": "bdev0",
                "output": {
                    "IO_Operations": 5,
                    "Bytes_Read": 7,
                    "Bytes_Written": 8
                }
            },
            {
                "Name": "bdev1",
                "output": {
                    "IO_Operations": 10,
                    "Bytes_Read": 20,
                    "Bytes_Written": 30
                },
{
                "Name": "bdev2",
                "output": {
                    "IO_Operations": 40,
                    "Bytes_Read": 50,
                    "Bytes_Written": 90
                }
            }
        ]
    }

海图代码

代码语言:javascript
复制
eon.chart({
    pubnub   : pubnub,
    history  : false,
    channel  : 'orbit5_volume',
    flow     : true,
    debug: true,
    generate : {
        bindto : '#chart',
        size: {
        height: 180,
        width: 500
    },
        data   : {
            x      : 'x',
            labels : true
        },
        axis : {
            x : {
                type : 'timeseries',
                tick : {
                    format : '%H:%M:%S'
                },
                zoom: {
                   enabled: true
                }
            }
        }
    },

    transform : function(m) {
        for (var i in m.devices){
           return { columns : [
            ['x', new Date().getTime()],
            ['Bytes Written', m.devices[i].output.Bytes_Read],
            ['Bytes Read', m.devices[i].output.Bytes_Written]
            ]
          }
        }
    }
});
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2015-10-28 20:14:56

您的图表代码转换循环覆盖每个数据的键,这就是为什么您只得到两个值。如果您使用i变量为每个数据提供一个新键,它将显示在图表上。

试试这个转换函数:

代码语言:javascript
复制
eon.chart({
    transform : function(m) {

        var obj = {columns: [
          ['x', new Date().getTime()]
        ]};

        for (var i in m.devices) {
           obj.columns.push(['Bytes Read ' + i, m.devices[i].output.Bytes_Read]);
           obj.columns.push(['Bytes Written ' + i, m.devices[i].output.Bytes_Written]]);
          }
        }

        return obj;
    }
});
票数 7
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/33232411

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档