jQuery 历史版本

来源:互联网 发布:电子杂志制作软件排行 编辑:程序博客网 时间:2024/04/28 23:32

      官方版本(权威全面详细):http://docs.jquery.com/Downloading_jQuery#Past_Releases Release Notes

      jQuery 1.0(2006年8月):该库的第一个稳定版本,已经具有了对CSS选择符、事件处理和AJAX交互的稳健支持。

  jQuery 1.1(2007年1月):这一版大幅简化了API。许多较少使用的方法被合并,减少了需要掌握和解释的方法数量。

  jQuery 1.1.3(2007年7月):这次小版本变化包含了对jQuery选择符引擎执行速度的显著提升。从这个版本开始,jQuery的性能达到了Prototype、Mootools以及Dojo等同类JavaScript库的水平。

  jQuery 1.2(2007年9月):这一版去掉了对XPath选择符的支持,原因是相对于CSS语法它已经变得多余了。这一版能够支持对效果的更灵活定制,而且借助新增的命名空间事件,也使插件开发变得更容易。

  jQuery UI(2007年9月):这个新的插件套件是作为曾经流行但已过时的Interface插件的替代项目而发布的。jQuery UI中包含大量预定义好的部件(widget),以及一组用于构建高级元素(例如可拖放的界面元素)的工具。

  jQuery 1.2.6(2008年5月):这一版主要是将Brandon Aaron开发的流行的Dimensions插件的功能移植到了核心库中。

  jQuery 1.3(2009年1月):这一版使用了全新的选择符引擎Sizzle,库的性能也因此有了极大提升。这一版正式支持事件委托特性。

  jQuery 1.3.2(2009年2月):这次小版本升级进一步提升了库的性能,例如改进了:visible/:hidden选择符、.height()/.width()方法的底层处理机制。另外,也支持查询的元素按文档顺序返回。

  jQuery 1.4(2010年1月14号对)代码库进行了内部重写组织,开始建立一些风格规范。老的core.js文件被分为attribute.js, css.js, data.js, manipulation.js, traversing.js和queue.js;CSS和attribute的逻辑分离。

      jQuery 1.5(2011年1月31日):该版本修复了83个bug,解决了460个问题。重大改进有:重写了Ajax模块;新增延缓对像(Deferred Objects);jQuery替身——jQuery.sub();增强了遍历相邻节点的性能;jQuery开发团队构建系统的改进。

     jQuery 1.6(2011年5月3日):重写了Attribute 模块和大量的性能改进。

     1.6新版本中的部分重要改进:

  • attr()、val()和data()方法有了更好的性能;
  • 在attr()方法中支持Boolean属性;
  • 添加了钩子函数,允许对attr()和val()方法进行扩展;
  • map()方法添加了对对象的支持(将JavaScript对象的属性映射到函数)
  • 允许使用相对值(“+=”,“-=”)更新CSS;
  • 添加了deferred.always(), deferred.pipe()方法,减少了代码量,提高了代码易读性;
  • 同步动画 – 现在所有动画都同步到相同的时间间隔. 使用新的浏览器功能,动画也更顺畅;
  • find(),closest()和is()可接收所有的DOM元素和JQuery对象作为参数。

不幸的是,其中包含了部分破坏性的变更,团队已经在官方更新中用单独的章节强调了它们:

变更JQuery 1.5.2 示例JQuery 1.6 示例data()方法使用破折号创建驼峰格式。
data-max-value="15" 创建{ max-value: 15 }data-max-value="15" 创建{ maxValue: 15 }区分了Property与Attribute。attr()方法现在不能用于获取preperty的值。为了处理property的值,引入了prop()和removeProp()方法。如果复选框被选中,checkbox.attr("checked")返回(true)



 checkbox.attr("checked")返回空字符串。
要判别是否选中,需在事件处理程序中使用
$(this).prop("checked")或
$(this).is(":checked")。

不出意外的话,第二项变更将会影响到现有打算升级到1.6的那些项目。

 

另附:

  1.4重要新特性:

  •常用方法的性能大幅提升:重写了大部分较早期的函数;

  •更容易使用的设置函数(setter function):为所有对象新增了许多易用的设置函数;

  •对Ajax的改进:引入了许多Ajax和JSON处理方面的更新,包括HTML5元素的序列化;

  •attribute(改进了.attr()的性能)、jQuery()核心函数、CSS(.css()性能有两倍提升)、特效和事件、DOM操作等也有显著改进

 JQuery1.42最新版本介绍

  jQuer1.4.2版本修复了1.4版本的一些错误和优化了一些不错的改进,速度比1.4.1版本又提升

  

  

了一倍,该版本对性能做了一些改进,同时增加了一些api ( .delegate() and .undelegate(). ),右图是JQuery各个版本的性能比较:

  jquery1.42新特性:

  加了两个新方法:.delegate() 和.undelegate(). 是对.live() and .die() 的补充. 这两个方法对特定的事件的起到简化。

  范例:

  $("table").delegate("td", "hover", function(){ $(this).toggleClass("hover"); });

  等于使用 .live():

  $("table").each(function(){ $("td", this).live("hover", function(){ $(this).toggleClass("hover"); }); });

  另外,以下代码中,.live() 基本上等同于 .delegate().

  $(document).delegate("td", "hover", function(){ $(this).toggleClass("hover"); });

  变更

  大量代码进行了重写, 提升了性能及修正了一些长期存在的问题。

  提升性能

  每次开发新的jquery版本,我们都努力去持续优化性能,以保证你能用到最高性能的javascript代码。

  在Taskspeed benchmark 的测试中,1.4.2比1.4.1快1倍,比1.3.2快2倍。

  主要是在下面4个方面进行了提升:

  .bind() 和 .unbind().

  .empty(), .remove(), 和 .html().

  插入单个DOM 节点到 document.

  $("body")

  在测试用例中,比较多的用到了 $("body"), .bind(), .unbind()方法,因此测试结果提升比较明显。

  v重写事件

  event handlers 不再作为一个对象属性保存在 jQuery的内部对象里。现在是保存在一个内部的对象数组里。v 现在可以通过调用.data("events") , 将会返回一个对象包含的所有事件类型。

  现在可以使用不同的数据、命名空间、事件类型绑定在同一个handler

  在一个handler清除自己之后,事件handler会继续执行

  不用关联数据或者命名空间到事件handler

  不用再使用代理方法

  事件执行的顺序在所有浏览器中得到保证,Google Chrome 中出现的对象循环逻辑问题已经得到解决.

   

原创粉丝点击