使用meta.tdAttr的网格列渲染器工具提示

Grid column renderer tooltip using meta.tdAttr

本文关键字:工具提示 网格 meta tdAttr 使用      更新时间:2023-09-26

我一直在尝试添加一个工具提示,当您将鼠标悬停在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

我觉得我可能在网格视图或网格面板上缺少了一些设置,但该属性甚至在元参数上都不可用,这似乎很奇怪。来自文件:

元数据:对象关于当前单元格的元数据的集合;可以由渲染器使用或修改。公认的属性有:tdCl、tdAttr和style。

我不知道为什么一开始没有这个设置,但我手动添加了它来解决这个问题:

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

它成功了!

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

        {
            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';
                }
            }
        }