javascript - 为什么 IE9 执行一些 JQuery 需要这么长时间?

标签 javascript jquery internet-explorer-9

我有一个应用程序,它在 ASPX 页面中为 HTML 表中的每个元素执行这段代码 (JQuery 1.4.2) (500x)

$(".ArtRow_" + artId).each(function () {  
 if ($(this).find(".ArtOpen_" + artId).length <= 0) return; 
.... };

省略 find 行会使此页面正常加载,但使用 find:

  • Firefox 和 Chrome:+- 3 秒
  • 在 IE9 中:+- 42 秒(在双核上使用 50% cpu)

我在 IE 中进行了分析,95% 的时间,IE 正在执行函数 CLASS (调用堆栈:find.f.filter.CLASS)

我试过了

  • 在查找中使用 ID
  • 通过使用固定类消除字符串连接

无济于事(42秒)

有人知道吗?提前致谢!

编辑:我现在确信每个都需要很长时间。我跳过了它,因为使用空代码块不需要 42 秒来加载 .但是加上一些注释行,又花了 42 秒,所以我猜这是某种不是很智能的死代码检测。

根据明确请求:ArtRow 所在的 HTML

 <tbody>
  <tr class="SB_ReceptielijstHeader">
    <th>Artikel / Bestelling</th>
    <th>Besteldatum</th>
    <th>Pr. School</th>
    <th>Pr. Levering</th>
    <th class="Number">Aantal besteld</th>
    <th class="Number">Aantal ontvangen</th>
  </tr>

  <tr class="SB_ReceptielijstArtikelHeader ArtRow_132109">
    <td id="Titel_132109" class="Artikel" colspan="5">
      <img src="images/SB/Icons/23-book.png" style="vertical-align:middle">&nbsp;9789030170433 - NANO 1</td>
      <td class="Number ArtikelTotal">
    <input type="hidden" value="132109" class="Artikel_Id">
      <input type="hidden" value="" id="ArtLevLn_132109">
        <input type="text" value="12" style="text-align:right" size="4" id="Aantal_132109" name="Aantal_132109" maxlength="4">
        </td>
      </tr>
      <tr class="SB_ReceptielijstRow ArtRow_132109 ArtRowInvisible">
        <td>Bestelling 81 / Lijn </td>
        <td>02/07/2010</td>
        <td>24,05</td>
        <td>22,85</td>
        <td class="ArtOpen_132109 Number">
        </td>
        <td id="ArtToew__132109" class="ArtToew ArtToew_132109 Number">
          <div style="display:none" class="ArtBestLn">
        <input type="hidden" value="">
        </div>
        <input type="text" style="text-align:right" size="4" id="Aantal_" name="Aantal_" maxlength="4"> 
        </td>
          </tr>

          <tr class="SB_ReceptielijstArtikelHeader ArtRow_134399">
        <td id="Titel_134399" class="Artikel" colspan="5">
          <img src="images/SB/Icons/23-book.png" style="vertical-align:middle">&nbsp;9789045533322 - HANDELWIJS 3 INCL CDROM HERWERKT 2010</td>
          <td class="Number ArtikelTotal">
            <input type="hidden" value="134399" class="Artikel_Id">
              <input type="hidden" value="" id="ArtLevLn_134399">
            <input type="text" value="25" style="text-align:right" size="4" id="Aantal_134399" name="Aantal_134399" maxlength="4">
            </td>
              </tr>
              <tr class="SB_ReceptielijstRow ArtRow_134399 ArtRowInvisible">
            <td>Bestelling 81 / Lijn </td>
            <td>02/07/2010</td>
            <td>23,95</td>
            <td>23,60</td>
            <td class="ArtOpen_134399 Number">
            </td>
            <td id="ArtToew__134399" class="ArtToew ArtToew_134399 Number">
              <div style="display:none" class="ArtBestLn">
                <input type="hidden" value="">
                </div>
                <input type="text" style="text-align:right" size="4" id="Aantal_" name="Aantal_" maxlength="4"> 
                </td>
              </tr>

            </tbody>

最佳答案

它很慢,因为它运行该代码 500 次。

我认为这不是您正在寻找的答案,因此如果您可以发布您的 HTML 结构,我们可以看看是否有一种方法可以优化您使用的选择器以使其更快。

关于javascript - 为什么 IE9 执行一些 JQuery 需要这么长时间?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8215495/

相关文章:

javascript - 使用 JavaScript 和 JQuery,如何维护动态更新的 HTML 选择元素的选定状态?

javascript - gRaphael - 动画折线图失败

javascript - "Hide div before scrolling"代码无论如何都不起作用

jQuery/CSS - 滑出式菜单(固定标题)

html - 删除 IE9 在 <img> 周围创建的神秘空间

javascript - Jquery ajax() 调用在 IE8 中失败

javascript - 在javascript中循环遍历json多维数组

javascript - 用 AM 排序日期和时间 |在 jquery 中PM

javascript - window.closed IE9 在窗口仍然打开时报告 true

javascript - 从数字文字访问 "getter"的属性时,IE9 中出现奇怪的 `Number.prototype` 行为