【老兵不朽】时隔1年,jQuery 发布新版 3.4.0

前言

jQuery 团队的核心开发者 Timmy Willison 在官网宣布了 jQuery 3.4.0,这距离上个版本 3.3.x 系列的推出已整整过去了一年多。

官方表示这可能是 3.x 分支的最后一个小版本更新,接下来的工作重心将是 jQuery 4.0 大版本的更新。

新版本特性

1、针对 .width 和 .height 的性能改进

在获取和设置维度时,在某些情况下,这可能会导致布局颠簸,这基本上意味着浏览器计算布局的次数超过了必要的次数。我们在IE以外的所有浏览器中修复了这个问题,这是无法避免的。

2、支持 nonce 和 noodle

为了支持通过.html和.append等方法添加脚本元素,jQuery将它们分开并附加新的脚本标记来加载和执行远程内容。在这个过程中,诸如nonce和nomodule被忽略的属性,但jQuery 3.4.0现在挂在它们上面。

3、针对 Radio 元素新增事件处理程序中的预期状态

在以下示例中,true第一次单击该元素时记录了该日志。我们修复它,以便checked在执行事件处理程序之前更新属性。
代码示例:

var $radios = jQuery(".example");
var $firstRadio = $radios.first();
var firstCheckedState = $firstRadio.prop("checked");
$radio.on("click", function() {
  // true in <3.4.0
  console.log($firstRadio.prop("checked") === firstCheckedState);
});
$radios.eq(1).click();
4、针对 Object.prototype pollution 问题的小修复

Query 3.4.0在使用时包含一些非预期行为的修复jQuery.extend(true, {}, ...)。如果未过滤的源对象包含可枚举__proto__属性,则它可以扩展本机Object.prototype。这个修复包含在jQuery 3.4.0中,但补丁差异存在以修补以前的jQuery版本。
代码示例:

jQuery.extend(true, {},
  JSON.parse('{"__proto__": {"test": true}}')
);
console.log( "test" in {} ); // true
5、弃用positional selectors and the sunset of Sizzle

jQuery的基本API是选择一些内容,然后对所选内容执行某些操作。Sizzle,jQuery中的选择器引擎,处理上半部分。它是一个快速有效的小引擎,为原生选择器API querySelectorAll和其他原生JavaScript和CSS选择器铺平了道路。现在很多这些选择器已经进入现代浏览器,现在几乎是时候告别Sizzle了。但是为了在jQuery 4.0中删除Sizzle,我们还需要删除我们称为位置选择器的东西,它们是非标准选择器。

具体而言,jQuery的3.4.0被弃用**:first,:last,:eq,:even,:odd,:lt,:gt,和:nth**。当我们删除Sizzle时,我们将用一个小包装器替换它,querySelectorAll如果没有更大的选择器引擎,几乎不可能重新实现这些选择器。

我们认为这种权衡是值得的。请记住我们仍然会支持的位置方法,如.first,.last和.eq。你可以用位置选择器做任何事情,你可以用位置方法来做。无论如何,它们表现更好。

升级

如果从jQuery 3.0+升级,应该没有兼容性问题。

更新日志

1、Ajax
2、Core
  • 使用isAttached检查元素的附件(662083ed
  • 微小的效率修复可jQuery.extend / 1.3中(#4246)(#42454ffb1df8
  • 保留在DOM操作与src属性的脚本CSP的随机数(#432300504037
  • 在DOM操作中保留脚本上的CSP nonce(#3541c7c2855e
  • 支持通过随机数通过jQuery.globalEval(#42785bdc85b8
  • 识别阴影DOM在附件检查(#35049b77def5
  • 防止$ .extend(true,…)的Object.prototype污染(753d591a
3、CSS
4、外形尺寸
  • 修复SVG上的计算外部宽度(#3964e743cbd2
  • 避免设置宽度/高度时,取boxSizing -这避免了迫使在某些情况下回流(#399173d7e625
  • 回落到offsetWidth /身高的边界框在IE(#4102315199c1
5、事件

精彩评论

精彩评论

精彩评论

贡献者

在这里插入图片描述

猜你喜欢

转载自blog.csdn.net/zhenghhgz/article/details/89328167