中文步骤之最佳实践.docxVIP

  1. 1、本文档共6页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  5. 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  6. 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  7. 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  8. 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
jQuery中文教程之最佳实践我主要参考了Addy Osmani的PPT《提高jQuery性能的诀窍》(jQuery Proven Performance Tips And Tricks)。他是jQuery开发团队的成员,具有一定的权威性,提出的结论都有测试数据支持,非常有价值。  1. 使用最新版本的jQuery  jQuery的版本更新很快,你应该总是使用最新的版本。因为新版本会改进性能,还有很多新功能。  下面就来看看,不同版本的jQuery性能差异有多大。这里是三条最常见的jQuery选择语句:  $(.elem)  $(.elem, context)  context.find(.elem)  我们用1.4.2、1.4.4、1.6.2三个版本的jQuery测试,看看浏览器在1秒内能够执行多少次。结果如下:  可以看到,1.6.2版本的运行次数,远远超过两个老版本。尤其是第一条语句,性能有数倍的提高。  其他语句的测试,比如.attr(value)和.val(),也是新版本的jQuery表现好于老版本。  2. 用对选择器  在jQuery中,你可以用多种选择器,选择同一个网页元素。每种选择器的性能是不一样的,你应该了解它们的性能差异。  (1)最快的选择器:id选择器和元素标签选择器  举例来说,下面的语句性能最佳:  $(#id)  $(form)  $(input)  遇到这些选择器的时候,jQuery内部会自动调用浏览器的原生方法(比如getElementById()),所以它们的执行速度快。  (2)较慢的选择器:class选择器  $(.className)的性能,取决于不同的浏览器。  Firefox、Safari、Chrome、Opera浏览器,都有原生方法getElementByClassName(),所以速度并不慢。但是,IE5-IE8都没有部署这个方法,所以这个选择器在IE中会相当慢。  (3)最慢的选择器:伪类选择器和属性选择器  先来看例子。找出网页中所有的隐藏元素,就要用到伪类选择器:  $(:hidden)  属性选择器的例子则是:  $([attribute=value])  这两种语句是最慢的,因为浏览器没有针对它们的原生方法。但是,一些浏览器的新版本,增加了querySelector()和querySelectorAll()方法,因此会使这类选择器的性能有大幅提高。  最后是不同选择器的性能比较图。可以看到,ID选择器遥遥领先,然后是标签选择器,第三是Class选择器,其他选择器都非常慢。  3. 理解子元素和父元素的关系  下面六个选择器,都是从父元素中选择子元素。你知道哪个速度最快,哪个速度最慢吗?  $(.child, $parent)  $parent.find(.child)  $parent.children(.child)  $(#parent .child)  $(#parent .child)  $(.child, $(#parent))  我们一句句来看。  (1) $(.child, $parent)  这条语句的意思是,给定一个DOM对象,然后从中选择一个子元素。jQuery会自动把这条语句转成$.parent.find(child),这会导致一定的性能损失。它比最快的形式慢了5%-10%。  (2) $parent.find(.child)  这条是最快的语句。.find()方法会调用浏览器的原生方法(getElementById,getElementByName,getElementByTagName等等),所以速度较快。  (3) $parent.children(.child)  这条语句在jQuery内部,会使用$.sibling()和javascript的nextSibling()方法,一个个遍历节点。它比最快的形式大约慢50%。  (4) $(#parent .child)  jQuery内部使用Sizzle引擎,处理各种选择器。Sizzle引擎的选择顺序是从右到左,所以这条语句是先选.child,然后再一个个过滤出父元素#parent,这导致它比最快的形式大约慢70%。  (5) $(#parent .child)  这条语句与上一条是同样的情况。但是,上一条只选择直接的子元素,这一条可以于选择多级子元素,所以它的速度更慢,大概比最快的形式慢了77%。  (6) $(.child, $(#parent))  jQuery内部会将这条语句转成$(#parent).find(.child),比最快的形式慢了23%。  所以,最佳选择是$parent.find(.child)。而且,由于$parent往往在前面的操作已经生成,jQuery会进行缓

文档评论(0)

wuyoujun92 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档