var tpl = new Ext.XTemplate(
'<tpl for=".">',
'<div class="thumb-wrap">',
'<img src="../images/warning.png" style="vertical-align: middle;" title="Warning">',
'<span class="x-editable" style="margin-left: 3px;">{text}</span></div>',
'</tpl>',
'<div class="x-clear"></div>'
);
var msg = store.proxy.lastDataTableObject.logMessages;
var topToolbar = this.gridPanel.topToolbar;
if (msg && msg.length > 0) {
//Warning Messages menu
topToolbar.insert(topToolbar.items.items.length - 1,{
text: "Warning Messages",
menu: {
xtype: 'menu',
autoScroll: true,
maxHeight: 200,
items: [
new Ext.DataView({
store: new Ext.data.SimpleStore({data: msg, fields: ['text']}),
tpl: tpl,
autoWidth: true,
multiSelect: true,
overClass: 'x-view-over',
itemSelector: 'div.thumb-wrap',
emptyText: 'No warnings to display'
})
]
}
});
topToolbar.doLayout();我做了这个菜单,里面有一个DataView。我的最终目标是添加maxHeight,使下拉元素的右上角始终锚定在按钮元素的右下角。
下面是目前发生的事情:

在固定高度下,锚定问题仍然存在,但至少菜单会按其应有的方式下降:

发布于 2014-08-16 17:33:24
您可以使用工具栏按钮上的menuAlign配置,其值为tr-br,它将元素的右上角(在您的情况下是菜单)对齐到目标的右下角(在您的情况下是该按钮)的右下角。
if (msg && msg.length > 0) {
topToolbar.insert(topToolbar.items.items.length - 1,{
text: "Warning Messages",
menuAlign: 'tr-br', // Add this line here
menu: {
xtype: 'menu',
...
}
});
topToolbar.doLayout();
}下面是一个基于代码的Sencha小提琴网站的工作实例,供您参考。

https://stackoverflow.com/questions/25268530
复制相似问题