Extjs 5 Chart Legend Issue

时间:2014-07-29 13:54:02

标签: extjs extjs5 extjs-chart

我正在尝试在我的extjs 5图表中添加legend,但它似乎无效。这是一个错误还是我做错了什么?

legend: {  
    docked: 'top',
    style: {
         borderColor: 'red',
         borderStyle: 'solid'
    }
}

2 个答案:

答案 0 :(得分:4)

我一直在研究同一个问题 - 并最终提交了Sencha Bug报告:

http://www.sencha.com/forum/showthread.php?289279-Sencha-5-Charts-Broken-Legend

长话短说,那里"据说"修复下一个EXTjs推出。不幸的是,这对我们现在没有帮助......

但是,您可以为图例创建一个tpl - 但我的tpl并不像原生的extjs图例那样强大。它仍会显示/隐藏系列,但不会掩盖图例中的系列。我还在改进TPL,并会在我开始工作时发布更新。

legend: {
        docked: 'top',
        border: 0,
        style: { borderColor: 'red' },
        tpl: [            
            '<tpl for=".">',                
                '<div class="myLegendItem" style="float:left;margin:5px;padding:0px;cursor:pointer;">',
                      '<div class="" style="float:left;margin:2px;width:10px;height: 10px; background:{mark};opacity:.6"></div><div style="float:left;">{name}</div>',                                      
                '</div>',                    
            '</tpl>'                
        ],
        itemSelector: '.myLegendItem'
},

答案 1 :(得分:2)

要屏蔽图例中的非活动系列,请使用三元运算符检查values.disabled

<div class="x-legend-container">
    <tpl for=".">
        <div class="x-legend-item {[ values.disabled ? Ext.baseCSSPrefix + 'legend-inactive' : '' ]}">
            <span class="x-legend-item-marker" style="background:{mark};float:left;width:10px;height:10px;"></span>
            <span style="float:left;margin-left:4px;">{name}</span>
        </div>
    </tpl>
</div>

如果需要,还为

添加一个css类
x-legend-inactive{
   opacity: 0.5;
}