JQuery效率问题

1,前言jquery

咱们开发了一个专题系统,生成了JSON的数据格式,采用JQuery动态插入HTML中,在前期的使用中,没有太大的问题,效率还能够接受,可是最近可能因为网络加之页面设计问题,咱们的JS效率比较差,长达10多秒中,实在难以忍受,究竟是什么缘由呢?网络

 

2,分析jsp

我观察了一下JS脚本,应该说没有太费时间的操做,采用ID的元素选择法,应该是最快的,虽然有个类选择器,可是元素不多,通常在2个左右,不至于影响效率,我注释一下,发现确实不是这个问题。函数

 

后来分析,多是HTML外面套的INDEX.JSP的问题,加上头尾后,效率很慢,因此咱们分析思路:设计

        2.1 把JSP分出top,bottom.jsp,采用jquery load()事件加入至页面,确实效率有所提高,可是在FF,和CHROME下不太正常,而调整后,都正常显示,可是效率又降低了。对象

        2.2 采用IFrame方式:把页面的头和尾部采用Iframe嵌入,去掉边框,固定大小,这个确实效率提升了,可是ifram里的跳转是个大问题,效果不是很好;事件

 

3,根本缘由开发

咱们吧注意力放在了JS上面,忽然想到,是否是$(document).ready()方法的缘由??文档

咱们去掉此方法,变为函数,同时在页面中用setTimeout()延时10毫秒触发,发现,正常了;效率

我网上查了一下read方法的说明:

当 DOM(文档对象模型) 已经加载,而且页面(包括图像)已经彻底呈现时,会发生 ready 事件。  
因为该事件在文档就绪后发生,所以把全部其余的 jQuery 事件和函数置于该事件中是很是好的作法。正如上面的例子中那样。  
ready() 函数规定当 ready 事件发生时执行的代码。  
ready() 函数仅能用于当前文档,所以无需选择器。
相关文章
相关标签/搜索