同事写了段JQuey的代码,在某些机器上,会出现IE假死的性能问题。

我测试了一下代码花费的时间,在我的机器上,会花费600多毫秒,但在某些机器上会花费6秒多(10倍的增长),这样就导致了IE的假死。而且发现与IE版本无关,在大多数机器上会都只需要600多毫秒,不过CPU会有10%以上的瞬间提长。

先来看看出问题的代码:

$(".eXtremeTable").replaceWith($(html).find(".eXtremeTable"));
$("#levelGroup").replaceWith($(html).find("#levelGroup"));
$("#scriptDiv").replaceWith($(html).find("#scriptDiv"));

其实这段代码很简洁,只是将用AJAX取过来的数据替换一部分当前页面的数据,但性能确实不够好。

开始找原因,看看到底是什么慢?

$(".eXtremeTable").replaceWith($(html).find(".eXtremeTable"));

将此行代码分拆,逐元素去分析各自花费的时间:
$(".eXtremeTable")  花费20毫秒左右;
$(html).find(".eXtremeTable")  花费200毫秒左右;
replaceWith()  花费10毫秒左右;
不难定位到是由于$(html).find(".eXtremeTable")这种方式引起的。
(这都是在我机器上的测试结果,而且每次可能不完全一样)

简单的可以这样优化:

var newPage=$(html);
$(".eXtremeTable").replaceWith(newPage.find(".eXtremeTable"));
$("#levelGroup").replaceWith(newPage.find("#levelGroup"));
$("#scriptDiv").replaceWith(newPage.find("#scriptDiv"));

但仔细想想,这样仍然会造成在某些机器上2秒以上的时间消耗,照样是不可接受的。

遂采用比较原始的办法,修改源程序如下:

     var tab='<span id=\"data\">';
            var pos=html.indexOf(tab)
            var content=html.substr(pos+tab.length);
            var pos2=content.indexOf('</span>');
            var content=content.substr(0,pos2);
            document.getElementById("data").innerHTML=content;
           // $(".eXtremeTable").replaceWith($(html).find(".eXtremeTable"));
          
            var counter='<td id=\"counter\" align=\"right\" width=\"300\">';
            pos=html.indexOf(counter)
            content=html.substr(pos+counter.length);
            pos2=content.indexOf('</table>');
            var content=content.substr(0,pos2+'</table>'.length);
            document.getElementById("counter").innerHTML=content;
           // $("#levelGroup").replaceWith($(html).find("#levelGroup"));

            var sel='<div id=\"scriptDiv\" style=\"display:none;\">'
            pos=html.indexOf(sel)
            content=html.substr(pos+sel.length);
            pos2=content.indexOf('</div>');
            var content=content.substr(0,pos2+'</div>'.length);
            document.getElementById("scriptDiv").innerHTML=content;            
           // $("#scriptDiv").replaceWith($(html).find("#scriptDiv"));

现在此段代码花费的时间几乎为0毫秒。

OK,IE再也不假死了。

问题分析:
原因应该就出在jQuery(html)这个方法上,官方文档解释如下:

根据提供的原始 HTML 标记字符串,动态创建由 jQuery 对象包装的 DOM 元素。 
你可以传递一个手写的 HTML 字符串,或者由某些模板引擎或插件创建的字符串,也可以是通过 AJAX 加载过来的字符串。但是在你创建 input 元素的时会有限制,可以参考第二个示例。当然这个字符串可以包含斜杠 (比如一个图像地址),还有反斜杠。当你创建单个元素时,请使用闭合标签或 XHTML 格式。例如,创建一个 span ,可以用 $("<span/>") 或 $("<span></span>") ,但不推荐 $("<span>") 
--------------------------------------------------------------------------------
Create DOM elements on-the-fly from the provided String of raw HTML. 
You can pass in plain HTML Strings written by hand, create them using some template engine or plugin, or load them via AJAX. There are limitations when creating input elements, see the second example. Also when passing strings that may include slashes (such as an image path), escape the slashes. When creating single elements use the closing tag or XHTML format. For example, to create a span use $("<span/>") or $("<span></span>") instead of without the closing slash/tag. 

因为要构建一个完整的DOM,所以需要花费较长的时间。

至于为何在某些机器上出现高达6秒多的时间消耗,百思不得其解,请高手指点!

一次JQuery性能优化实战的更多相关文章

  1. jQuery性能优化指南(转载)

    现在jquery应用的越来越多, 有些同学在享受爽快淋漓coding时就将性能问题忽略了, 比如我. jquery虽在诸多的js类库中性能表现还算优秀, 但毕竟不是在用原生的javascript开发, ...

  2. jQuery性能优化的28个建议

    我一直在寻找有关jQuery性能优化方面的小窍门,能让我那臃肿的动态网页应用变得轻便些.找了很多文章后,我决定将最好最常用的一些优化性能的建议列出来.我也做了一个jQuery性能优化的简明样式表,你可 ...

  3. 网站性能优化实战——从12.67s到1.06s的故事

    文章摘自https://juejin.im/post/5b0b7d74518825158e173a0c 作为互联网项目,最重要的便是用户体验.在举国“互联网+”的热潮中,用户至上也已经被大多数企业所接 ...

  4. jQuery:jQuery性能优化28条建议

    http://www.xue5.com/WebDev/jQuery/671700.html 直在寻找有关jQuery性能优化方面的小窍门,能让我那臃肿的动态网页应用变得轻便些.找了很多文章后,我决定将 ...

  5. jquery性能优化的十种方法

    jquery性能优化的十种方法 有时候我们在书写jquery的时候,为了书写代码方便,往往忽略了程序执行过程中,给客户端带来的压力.随之而来的就是在某些低端浏览器或者低端电脑上运行速度缓慢,甚至无法运 ...

  6. jQuery 性能优化技巧

    原文地址:jQuery 性能优化技巧 博客地址:http://www.extlight.com 一.使用最新版本 jQuery 类库 二.合理使用选择器 # 推荐使用 $("#id" ...

  7. jQuery性能优化和技巧

    jQuery性能优化 ①使用最新版本的jQuery类库 ②使用合适的选择器 ③缓存对象 ④循环时的DOM操作 ⑤数组方式使用jQuery对象 ⑥事件代理 ⑦将你的代码转化成jQuery插件 ⑧使用jo ...

  8. 28个jQuery性能优化的建议

    我一直在寻找有关jQuery性能优化方面的小窍门,能让我那臃肿的动态网页应用变得轻便些.找了很多文章后,我决定将最好最常用的一些优化性能的建议列出来.我也做了一个jQuery性能优化的简明样式表,你可 ...

  9. 小程序Canvas性能优化实战

    以下内容转载自totoro的文章<小程序Canvas性能优化实战!> 作者:totoro 链接:https://blog.totoroxiao.com/canvas-perf-mini/ ...

随机推荐

  1. vector.resize 与 vector.reserve的区别 .xml

    pre{ line-height:1; color:#9f1d66; background-color:#a0ffc0; font-size:16px;}.sysFunc{color:#5d57ff; ...

  2. Java核心 --- 枚举

    Java核心 --- 枚举 枚举把显示的变量与逻辑的数字绑定在一起在编译的时候,就会发现数据不合法也起到了使程序更加易读,规范代码的作用 一.用普通类的方式实现枚举 新建一个终态类Season,把构造 ...

  3. 闭包在python中的应用,translate和maketrans方法详解

    python对字符串的处理是比较高效的,方法很多.maketrans和translate两个方法被应用的很多,但是具体怎么用常常想不起来. 让我们先回顾下这两个方法吧: 1.s.translate(t ...

  4. MFC知识点(DDX_Control 与 DDX_Text ,ON_COMMAND和ON_MESSAGE)

    1.DDX_Control 与 DDX_Text 区别 DDX_TEXT()的作用可以理解为把字符串变量和控件的文本(WindowText)关联起来, DDX_Control()的作用可以理解为把变量 ...

  5. TIME_WAIT是什么?http连接

    http连接分为:建立连接,即tcp三次握手 发送请求信息 发送响应信息 关闭连接(tcp四次握手):下面讲此过程: 在TCP断开的过程中会有四个状态变化过程,如下图所示: 在连接撤销过程中,有如下过 ...

  6. Hybrid App简介

    Hybrid App 是混合模式应用的简称,兼具 Native App 和 Web App 两种模式应用的优势,开发成本低,拥有Web技术跨平台特性.目前大家所知道的基于中间件的移动开发框架都是采用的 ...

  7. 设置sudo权限

    由于CentOS安装之后,普通用户无sudo权限,故应该设置sudo权限. 此处假设当前用户为“cloudgis”. 1. 设置sudo权限,则设置如下: $ su root 输入root 密码 $ ...

  8. Hadoop 1.1.2 Eclipse 插件使用——异常解决

    permission denied user 1.修改配置文件在conf/hdfs-site.xml文件中添加如下内容: <property> <name>dfs.permis ...

  9. kali系统安装图文教程

    工具和原料 1.虚拟机:Oracle VM VirtualBox 下载地址:https://www.virtualbox.org/wiki/Downloads 根据你自己的计算机操作系统下载,其中如果 ...

  10. [转]比较 Rational Unified Process (RUP) 和 Microsoft Solutions Framework (MSF)

      文档选项 将此页作为电子邮件发送 级别: 初级 Sandra Sergi Santos, 软件工程专家, IBM 2007 年 6 月 15 日 本文来自于 Rational Edge:Micro ...