1

当自定义按钮添加到子网格(使用 jqgrid navButtonAdd)但仅在 FireFox 和 IE 中时,导航按钮(无论是在 toppager 还是常规寻呼机上)是否存在错误?它似乎在 Chrome 中工作/看起来很好 - 父网格的自定义按钮在 Firefox 和 IE 中也可以正常工作,这只是一个外观问题/悬停和大小问题,仅作为这些浏览器的子网格出现在网格中。

这是按钮大小和悬停位置的错误。

查看这张图片以了解我的意思:http: //i.imgur.com/YLroY.png

我的代码(在子网格的 subGridRowExpanded 属性中)是这样的:

jQuery("#" + subgrid_table_id).jqGrid('navButtonAdd','#RedirectsTable_' + row_id + '_t_toppager_left',
{
    caption : "Add New Region Url... ", buttonicon : 'ui-icon-plus',
    id : "btnAddNewRegionUrl_" + subgrid_table_id,
    onClickButton : function()
    {
        addNewRegionUrlRow("#" + subgrid_table_id, row_id);
    }
}).jqGrid('navButtonAdd','#RedirectsTable_' + row_id + '_t_toppager_left',
        {
            caption : "Copy All ", buttonicon : 'ui-icon-copy',
            id : "btnCopyRegionUrls_" + subgrid_table_id,
            onClickButton : function()
            {
                copyRegionUrlRows(row_id);
            }
        }); // etc chaining them like this.  Also, I add buttons in this manner for the parent grid and to the bottom pager as well

任何解决此问题的帮助将不胜感激。

谢谢!:)

4

1 回答 1

1

我仍然认为这是一个错误,并希望有人能帮助解释为什么这只发生在子网格中并且只发生在 FireFox 和 IE 而不是 Chrome 中......?

但是,我想我会发布一个 hack,这不是解决此问题的“正确方法”,但它在外观上确实有效。

在父网格的 colModel 的subGridRowExpanded属性中,我将以下代码放在gridComplete事件属性中,以便在网格完成并准备好使用后设置这些子网格导航按钮的宽度。至少可以说这是一个不雅的技巧,但它确实有效。

显然,这是对宽度进行硬编码,这是令人讨厌的 - 如果按钮文本是来自数据库或其他东西的动态文本,则它将不起作用,但对我来说这没关系。

所以我检查了 Chrome 报告的“正确”宽度,然后添加了这段代码(显然用你的 navButtonAdd 按钮 id 代替我的):

 gridComplete : function()
    {
    //hack for FF & IE widths dont work in subgrid nav buttons- bug in jqgrid?
    $("#btnAddNewRegionUrl_" + subgrid_table_id).children(".ui-pg-div").width("133px");
    $("#btnCopyRegionUrls_" + subgrid_table_id).children(".ui-pg-div").width("63px");
    $("#btnPasteRegionUrls_" + subgrid_table_id).children(".ui-pg-div").width("63px");
    }

希望这是有用的 - 但如果您有任何意见或建议,请加入。@奥列格?

谢谢 :)

于 2011-09-15T00:18:36.977 回答