jqGrid 在 Chrome/Chrome 框架中无法正确呈现

IT技术 javascript jquery css google-chrome jqgrid
2021-01-15 08:25:04

目前使用 Chrome v19.0.1084.46 (Official Build 135956) beta-m jqGrid 4.3.2 (最新版本)

问题是,无论我的网格、列或包含 div 的大小如何,最后一列的一小部分都会被推到网格边缘之外,从而导致出现水平滚动条,这是不应该发生的。见下文:

网格

我一直在摆弄 jqGrid 上的以下属性来尝试解决这个问题:

  • width
  • autowidth
  • height
  • shrinkToFit
  • scrollOffset - 最好的运气,但没有什么可重复的。

我也只精简到基本的网格 css,认为这可能是我制定的规则......没有运气。

有没有其他人经历过这个和/或找到了解决方案?非常感谢帮助。

6个回答

我今天将我的 Chrome 更新到版本 19,重现了该问题并进行了相应的快速修复:

我建议改变线路的jqGrid的代码

isSafari = $.browser.webkit || $.browser.safari ? true : false;

到以下

isSafari = ($.browser.webkit || $.browser.safari) &&
    parseFloat($.browser.version)<536.5 ? true : false; // Chrome < version 19

演示使用修复程序。jquery.jqGrid.src.js我在演示中使用的固定版本,您可以在此处获取

我在 IE9 (v9.0.8112.16421), IE8 (8.0.6001.18702CO), Chrome 18.0.125.168, Chrome 19.0.1084.46, Safari 5.1.7 (7534.57.2), .1216 Firefox .1216 . 在所有 Web 浏览器中,演示都没有水平滚动条,如下所示:

在此处输入图片说明

将来最好将网格宽度的计算更改得更深,以不直接依赖于任何版本号或 Web 浏览器。我希望如果jqGrid的某些地方使用更多的 jQuery 方法$.width$.outerWidth是可能的。无论如何,我希望上述修复程序已经对许多 jqGrid 用户有所帮助。

更新:我将我的建议作为错误报告发布给 trirand

更新2:为了刚好有在代码三个地方使用相同的$.browser.webkit || $.browser.safari构建体如上述:内部setGridWidth的getOffset的内部宽度的计算的内部multiselect柱,内部showHideCol内部setGridWidth前三个地方使用isSafari变量。后两处$.browser.webkit || $.browser.safari直接使用应该在所有地方替换代码

$.browser.webkit||$.browser.safari

($.browser.webkit || $.browser.safari) && parseFloat($.browser.version)<536.5

因此,应该在三个地方执行此操作

  1. isSafari(见我原帖)的定义
  2. 代替 showHideCol
  3. 代替 setGridWidth

您可以jquery.jqGrid.src此处下载带有所有修复程序的固定版本jquery.jqGrid.src如果您必须使用旧版本的 jqGrid,您可以在自己的代码中进行相同的更改要为生产创建最小化版本,您可以使用任何您熟悉的最小化程序。我使用例如 Microsoft Ajax Minifier 4.0。只需安装并执行

AjaxMin.exe jquery.jqGrid.src-fixed3.js -o jquery.jqGrid.min-fixed3.js

结果你会得到jquery.jqGrid.min-fixed3.js,它会比原来的更小jquery.jqGrid.min.js即使您将注释标题添加到文件中(请参阅修改后的文件),该文件仍将比jquery.jqGrid.min.js.

在对我的错误报告改进进行了一些迭代之后,还有一个版本的修复程序cellWidth引入了该方法

cellWidth : function () {
    var $testDiv = $("<div class='ui-jqgrid' style='left:10000px'><table class='ui-jqgrid-btable' style='width:5px;'><tr class='jqgrow'><td style='width:5px;'></td></tr></table></div>"),
        testCell = $testDiv.appendTo("body")
            .find("td")
            .width();
        $testDiv.remove();
        return testCell !== 5;
}

这里如果您更喜欢遵循这种方式,也可以这样做。在所有使用isSafarior $.browser.webkit || $.browser.safari(in showHideColand setGridWidth) 的地方的情况下,您可以$.jgrid.cellWidth()改用。

更新 3:今天发布了 jqGrid 4.3.3,其中包含我上面描述的修复程序(cellWidth方法)。所以我推荐大家使用新版本。

更新 4: Google Chrome 20 使用 WebKit 536.11。因此,不能使用具有固定宽度计算的最新版本的 jqGrid 的每个人都应该使用parseFloat($.browser.version)<536.11(或接近)而不是parseFloat($.browser.version)<536.5答案开头的描述。Google Chrome 23 WebKit 使用 537.11。

问题是我的网格宽度完全搞砸了链接
2021-03-18 08:25:04
@user648929:我无法调试图片!要进行适用于您的情况的新修复,我需要有重现问题的演示您应该发布重现问题的JavaScript 代码
2021-03-22 08:25:04
@史蒂夫:这是正确的。这是4.3.3发布的最重要原因之一。上周我请托尼这样做,但他很忙,今天才发布了 4.3.3。我将添加“更新 3:”。
2021-03-30 08:25:04
@JustinEthier:你说得对!目前的cellWidth函数代码还存在一个bug 我想我可以稍微改进一下代码。看看我的评论
2021-04-06 08:25:04
我升级到 4.3.3,这不再是问题。
2021-04-09 08:25:04

奥列格的解决方案对我有用。

我刚刚编辑了最小版本

第 49 行:

替换:

m=b.browser.webkit||b.browser.safari?!0:!1

和:

m=(b.browser.webkit||b.browser.safari)&&parseFloat(b.browser.version)<536.5?!0:!1

谢谢您的帮助!

只是想补充一点,这不是一个通用的解决方案。如果它对你有用,那很好,但你可能想看看 Oleg 的更新和最近的答案。
2021-04-11 08:25:04

奥列格的回答是正确的。但是,如果您使用旧版本的 jqGrid 并希望应用这些修复程序,则直接从 Github 上的差异中获取更改可能更容易。我已经使用 jqGrid 4.0.0 成功地测试了这个,所以大概它可以在任何 4.x 系列上工作。

只需从第一个差异开始并按顺序应用它们。这将添加cellWidth函数并在 jquery.jqGrid.src.js 文件中进行所有必要的更改。然后,如果您想创建缩小版本,则可以使用 Google 闭包编译器:

看起来有很多变化,但是当您查看实际代码时,这些变化会很快发生。只有少数源代码行受到影响。

Chrome beta 20.0.1132.11 已发布并报告以下内容:

User-Agent:Mozilla/5.0 (Windows NT 5.1) AppleWebKit/536.11 (KHTML, like Gecko) Chrome/20.0.1132.11 Safari/536.11

我猜 536.11 评估为 < 536.5 由于数字与文本比较导致补丁不起作用?

请帮忙!

我在 Chromium 版本 20.0.1132.57 (0) 中看到了这个错误。我目前正在使用 jqGrid 4.4.0。有人应该测试最近发布的 Safari 6 并更改代码以执行旧浏览器的蹩脚行为,而不是试图破解总是会发生的新版本。
2021-03-20 08:25:04
jqGrid 在线演示已更新为最新版本的 jqGrid,其中包含 Oleg 的修复程序。使用 Chrome 20 时,您是否仍然在该页面上看到问题?
2021-04-03 08:25:04
这是评论而不是答案。此外,奥列格的回答已经在他的“更新 4”中涵盖了这一点。
2021-04-04 08:25:04

更新:我的回答指的是几个月前在 Firefox 中发生的类似问题,我建议希望它适用于 Chrome 19,但目前 Oleg 的答案是正确的方法。

几个月前我在 FF 上遇到了类似的问题,我正在使用 ForceFit 选项,该选项应该完全禁用 HScroll,但就像你提到的那样,我仍然会得到它,所以我只是禁用了我的 forcefit 网格的 HScroll。FF 的一些更新之后,它确实停止了,目前我所有的网格在 Chrome 18 中都很好,所以希望在 19 发布时它不会成​​为问题。

//remove HScroll
function jqGridDisableHScroll(gridid) {
    //if columns are force fit all columns will always fit on screen.
    if ($('#' + gridid).jqGrid('getGridParam', 'forceFit')) {
        var gridview = $('#gview_' + gridid);
        $('.ui-jqgrid-bdiv', gridview).css({ 'overflow-x': 'hidden' });
    }
}

力配合

如果设置为 true,并调整列的宽度,则相邻列(右侧)将调整大小以保持整个网格宽度(例如,将第 2 列的宽度减少 30px 将使第 3 列的大小增加30 像素)。在这种情况下,没有水平滚动条。注意:此选项与shrinkToFit 选项不兼容——即如果shrinkToFit 设置为false,则忽略forceFit。

澄清一下,问题出在 jqGrid 和 Chrome 19 上;有关完整详细信息,请参阅 Oleg 的回答。
2021-03-16 08:25:04
好吧,这很不幸,因为如果 Chrome 19 发布时此问题仍然存在,我将与您处于同一条船上。您能否在演示页面trirand.com/blog/jqgrid/jqgrid.html上确认网格是否存在此问题
2021-03-21 08:25:04
您是否也将 forcefit 设置为 true?
2021-03-23 08:25:04
不幸的是,它似乎不起作用。demo'd 函数成功移除了滚动条,但内容仍然溢出网格区域,无论shrinkToFit.
2021-03-25 08:25:04
是的,我根据文档将 forcefit 设置为 true。像问题看起来都那里的演示页
2021-04-01 08:25:04