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

mulan 2019-04-12 17:18:49 ⋅ 913 阅读

前言

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
  • 当使用脚本传输允许自定义属性(#3028,1f4375a3)

  • 修复IE11的getResponseHeader(key)(#3403,e0d94115)

2、Core
  • 使用isAttached检查元素的附件(662083ed)

  • 微小的效率修复可jQuery.extend / 1.3中(#4246)(#4245,4ffb1df8)

  • 保留在DOM操作与src属性的脚本CSP的随机数(#4323,00504037)

  • 在DOM操作中保留脚本上的CSP nonce(#3541,c7c2855e)

  • 支持通过随机数通过jQuery.globalEval(#4278,5bdc85b8)

  • 识别阴影DOM在附件检查(#3504,9b77def5)

  • 防止$ .extend(true,...)的Object.prototype污染(753d591a)

3、CSS
  • 确保CSS变量不会折叠camel- vs kebab-cased名称(f8c1e902)

  • 避免填满jQuery.cssProps(#3986,2b5f5d5e)

  • 正确地检测与非默认缩放滚动框支持(#4029,821bf343)

  • 不要自动追加“PX”到CSS的变量(#4064)(#4063,75b77b48)

  • 跳过非元素道具动画的px- appending逻辑(f5e36bd8)

  • 除非必要,否则避免在宽度/高度吸气剂中强制回流(#4322,a0abd15b)

  • 除非必要,否则不要在宽度/高度cssHook中读取styles.position(#4185,354f6036)

  • 不要将“px”自动附加到可能无单位的CSS网格属性(#4007,f997241f)

4、外形尺寸
  • 修复SVG上的计算外部宽度(#3964,e743cbd2)

  • 避免设置宽度/高度时,取boxSizing -这避免了迫使在某些情况下回流(#3991,73d7e625)

  • 回落到offsetWidth /身高的边界框在IE(#4102,315199c1)

5、事件
  • 阻止来自双击焦点的leverageNative(fe5f04de)

  • 添加“代码”属性,事件对象(#3978,899c56f6)

  • 利用原生事件进行聚焦/模糊/点击; 传播的附加数据(#1741,#3423,#3751,#4139,669f720e)

  • 尊重DOM操作中的脚本nomodule属性(#4281,e4de8b46)

  • 恢复_evalUrl jQuery.ajax调用dataType:script(13de7c9e)

  • 仅评估HTTP成功的脚本src(#4126,c2026b11)

精彩评论


精彩评论


精彩评论

贡献者

  • IT实战联盟-Line


---------------END----------------

后续的内容同样精彩

长按关注“IT实战联盟”哦




全部评论: 0

    我有话说:

    「尝鲜」SpringBoot 快速整合Swagger 3.0

    第一步:Maven引入Swagger3.0 starter依赖 Maven项目中引入springfox-boot-starter依赖: <dependency> <

    SQLiteStudio 3.3.0 发布时隔的更新

    在经过近 3 时间之后,SQLiteStudio 3.3.0 版本现已发布。SQLiteStudio 是一个跨平台的 SQLite 数据库的管理工具,采用 Tcl 语言开发

    phpPgAdmin 7.13.0 发布

    phpPgAdmin 7.13.0版本于今天发布。该版本涉及以下更新: 增加对Postgres 13的支持; 增加对Postgres 14的暂时适配; 升级Jquery库为jquery 3.4.1

    【推荐】前端框架 Bootstrap 5.0 alpha 发布不再依赖 jQuery

    Bootstrap 5 的两个重要变化是,它不再依赖 jQuery,并且不再支持 Internet Explorer。

    Spring Boot 2.4.0-RC1, 2.1.18, 2.2.11 和 2.3.5 发布

    Spring Boot 多个分支发布了新版本,分别是 2.4.0-RC1, 2.1.18, 2.2.11 和 2.3.5。 Spring Boot 2.4.0-RC1 此版本是 

    Scala.js 1.4.0 发布,将 Scala 编译成 JavaScript

    Scala.js 1.4.0发布。Scala.js 是一个将 Scala 语言编译成 JavaScript 的工具,以便可以直接在浏览器上使用 Scala 编写程序。 Scala.js

    Swagger接口文档工具:Knife4j 2.0.7 发布,细节优化

    Knife4j前身是swagger-bootstrap-ui,是一个为Swagger接口文档赋能的工具 文档:https://doc.xiaominfo.com 效果(旧版):http

    jQuery 3.6.0 发布,即使存在 JSONP 错误也返回 JSON

    jQuery 是一个快速、小型且功能丰富的 JavaScript 库。通过易于使用的 API(可在多种浏览器中使用),使 HTML 文档的遍历和操作、事件处理、动画和 Ajax 等操作变得更加简单

    前端框架 Angular 11.0.0 正式发布不再支持 IE 9 、10

    前端框架 Angular 11.0.0 正式发布。 Angular 11.0.0 将 TypeScript 升级到 4.0, 对 TypeScript 3.9 不再支持。 放弃了对 IE 9 、10

    FileZilla Client 3.53.0-rc1 发布,FTP 客户端

    FileZilla Client 3.53.0-rc1 发布了。FileZilla 是一种快速、可信赖的 FTP 客户端以及服务器端开源程序,具有多种特色、直观的接口。FileZilla

    Eclipse Jetty 9.4.38、10.0.1 和 11.0.1 发布

    Eclipse Jetty 9.4.38、10.0.1 和 11.0.1 已经发布。这三个版本都包含了大量的 bug 修复和改进,建议所有用户尽快升级。重要的是,这些版本涉及 CVE-2020

    CrateDB 4.3.1 发布,分布式 SQL 数据库

    CrateDB 4.3.1发布。Crate 是一个开源的大规模的可伸缩的数据存储系统,无需任何系统管理需求。提供强大的搜索功能。用于存储各种表格数据、非结构化数据和二进制对象。并可通过 SQL

    Scala 3 来了,Dotty 发布 3.0.0-M1 版本

    Dotty 发布3.0 的首个里程碑版本 3.0.0-M1,Dotty 作为 Scala 尝试新的语言概念以及编译器技术的研究平台,它最终将成为 Scala 3.0。 Dotty 对

    Apache HBase 最新发布2.0.4 ,分布式数据库

    HBase 2.0.4 主要修复了 2.0.3 和 2.1.1 版本中 HBASE-21551 Bug。此外还包括 31 项 Bug 修复。

    Taro UI 2.0 发布新增自定义主题功能,适配更多小程序

    Taro UI 发布已有半,在此期间,不断完善组件库的功能和特性,新增了许多组件和小工具...

    Angular 11.1.0 正式发布,支持 TypeScript 4.1

    。 近日,Angular 11.1.0 正式发布...

    FileZilla Client 3.52.0 发布,FTP 客户端

    FileZilla Client 3.49.0-rc1 发布了。FileZilla 是一种快速、可信赖的 FTP 客户端以及服务器端开源程序,具有多种特色、直观的接口。FileZilla

    「360技术」Pika 3.4.0 发布,从单机到集群

    pika 3.4.0 发布了。pika 是 360 公司发布一个可持久化的大容量 redis 存储服务,兼容 string、hash、list、zset、set 的绝大部分接口,解决 redis