1

我一直在尝试添加一个工具提示,当您将鼠标悬停在 Ext.grid.Panel 中的单元格上时会弹出该工具提示。

但是,列的渲染器函数的参数“meta”没有 tdAttr 属性!

renderer : function(value, meta, record, row, col) {
    if (value == 1 && record.data.state === 'Accepted') {
        meta.tdCls = 'green';
        console.log('value',value);
        console.log('meta',meta);
        console.log('meta.tdAttr',meta.tdAttr);
        console.log('meta.style',meta.style);
        meta.tdAttr = 'data-qtip="' + value + '"';
        return record.data.id;
    } else if (value == 1 && record.data.state === 'Initial Version') {
        meta.tdCls = 'white';
        return record.data.id;
    } else if (value == 1) {
        meta.tdCls = 'red';
        return record.data.id;
    } else {
        return '';
    }
}

示例控制台输出:

value 1 
meta Object {tdCls: "", style: ""} 
meta.tdAttr undefined 
meta.style

我觉得我可能缺少网格视图或网格面板上的一些设置,但是对于该属性甚至在元参数上都不可用似乎很奇怪。从文档中:

metaData : Object 关于当前单元格的元数据集合;可以由渲染器使用或修改。可识别的属性有:tdCls、tdAttr 和 style。

4

2 回答 2

1

我不知道为什么一开始就没有该设置,但我手动添加它以解决该问题:

meta['tdAttr'] = 'data-qtip="' + value + '"';

它奏效了!

于 2013-08-20T16:55:23.000 回答
0

我有在操作列中动态显示单元格工具提示的经验,应该会有所帮助。

        {
            xtype: 'actioncolumn',
            name: 'payment',
            width: 70,
            align: 'center',
            dataIndex: 'uid',
            menuDisabled: 'true',
            text: 'xxx',
            sortable: false,
            fixed: 'true',
            renderer: function (value, metadata, record) {
                if (value == '0') {
                    metadata.tdCls = 'pay-icon';
                }
                else {
                    metadata.tdCls = 'paid-icon'
                }
            },
            getTip: function (value, metadata, record) {
                if (value == '0') {
                    return 'for pay';
                } else {
                    return 'paid';
                }
            }
        }
于 2013-08-20T06:39:48.327 回答