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

编程之家收集整理的这篇文章主要介绍了【老兵不朽】时隔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
    @H_404_56@当使用脚本传输允许自定义属性(#3028,1f4375a3)@H_404_56@修复IE11的getResponseHeader(key)(#3403,e0d94115)
2、Core
    @H_404_56@使用isAttached检查元素的附件(662083ed)@H_404_56@微小的效率修复可jQuery.extend / 1.3中(#4246)(#4245,4ffb1df8)@H_404_56@保留在DOM操作与src属性的脚本CSP的随机数(#4323,00504037)@H_404_56@在DOM操作中保留脚本上的CSP nonce(#3541,c7c2855e)@H_404_56@支持通过随机数通过jQuery.globalEval(#4278,5bdc85b8)@H_404_56@识别阴影DOM在附件检查(#3504,9b77def5)@H_404_56@防止$ .extend(true,…)的Object.prototype污染(753d591a)
3、CSS
    @H_404_56@确保CSS变量不会折叠camel- vs kebab-cased名称(f8c1e902)@H_404_56@避免填满jQuery.cssProps(#3986,2b5f5d5e)@H_404_56@正确地检测与非默认缩放滚动框支持(#4029,821bf343)@H_404_56@不要自动追加“PX”到CSS的变量(#4064)(#4063,75b77b48)@H_404_56@跳过非元素道具动画的px- appending逻辑(f5e36bd8)@H_404_56@除非必要,否则避免在宽度/高度吸气剂中强制回流(#4322,a0abd15b)@H_404_56@除非必要,否则不要在宽度/高度cssHook中读取styles.position(#4185,354f6036)@H_404_56@不要将“px”自动附加到可能无单位的CSS网格属性(#4007,f997241f)
4、外形尺寸
    @H_404_56@修复SVG上的计算外部宽度(#3964,e743cbd2)@H_404_56@避免设置宽度/高度时,取BoxSizing -这避免了迫使在某些情况下回流(#3991,73d7e625)@H_404_56@回落到offsetWidth /身高的边界框在IE(#4102,315199c1)
5、事件
    @H_404_56@阻止来自双击焦点的leverageNative(fe5f04de)@H_404_56@添加代码属性,事件对象(#3978,899c56f6)@H_404_56@利用原生事件进行聚焦/模糊/点击; 传播的附加数据(#1741,#3423,#3751,#4139,669f720e)@H_404_56@尊重DOM操作中的脚本nomodule属性(#4281,e4de8b46)@H_404_56@恢复_evalUrl jQuery.ajax调用dataType:script(13de7c9e)@H_404_56@仅评估HTTP成功的脚本src(#4126,c2026b11)

精彩评论

精彩评论

精彩评论


总结

以上是编程之家为你收集整理的【老兵不朽】时隔1年,jQuery 发布新版 3.4.0全部内容,希望文章能够帮你解决【老兵不朽】时隔1年,jQuery 发布新版 3.4.0所遇到的程序开发问题。

如果觉得编程之家网站内容还不错,欢迎将编程之家网站推荐给程序员好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您喜欢寻找一群志同道合、互帮互助的学习伙伴,可以点击下方链接加入:
编程之家官方1群
编程之家官方2群
编程之家官方3群
编程之家官方4群

相关文章

猜你在找的jQuery相关文章

目录验证码实现效果如下:生成验证码的方法:生成验证码随机背景颜色在html中引用完整源码下载地址:验证码实现效果如下:生成验证码的方法:function code_draw() { var canvas_width = $('#canvas').width(); var canvas_height = $('#canvas').height(); var canvas = document.getElementById("canvas"); //获取到canvas
比如info是一个字符串变量,如果需要去该变量的值,需要使用下面的语句:语法:alert($(&quot;#&quot;+id).val());例如:使用id设置隐藏控件 $(&quot;.img&quot;).mouseover(function(event){ var html=event.target.innerHTML; //alert(html); var aid=html.match(/&amp;lt;a id=&quot;(...
使用js去除字符串内所带有空格,有以下三种方法:( 1 ) replace正则匹配方法去除字符串内所有的空格:str = str.replace(/s*/g,&quot;&quot;);去除字符串内两头的空格:str = str.replace(/^s*|s*$/g,&quot;&quot;);去除字符串内左侧的空格:str = str.replace(/^s*/,&quot;&quot;);去除字符串内右侧的...
1.开启disabled,是input不可以编辑$(&quot;#input_id&quot;).attr(&quot;disabled&quot;,&quot;disabled&quot;);2.关闭disabled$(&quot;#input_id&quot;).removeAttr(&quot;disabled&quot;);普通js中是这样写的,document.getElementById(&quot;input_id&quot;).disabled = false;...
最近自学了一段时间的HTML、CSS、JavaScript、jQuery。通过自己这段时间学到的一点小知识,自己制作了一个小app------简易备忘录在此简单记录一下,同时也希望有更好创意的朋友提出改进意见或者指++++++++++++++++++++++++++++++++++++++++++++++++++++++++++开发工具:HBui
http://www.runoob.com/jquery/jquery-chaining.htmljQuery- 链(Chaining)通过jQuery,可以把动作/方法链接在一起。Chaining允许我们在一条语句中运行多个jQuery方法(在相同的元素上)。jQuery方法链接直到现在,我们都是一次写一条jQuery语句(一条接着另一条)。不过,有一
jQuery拥有以下滑动方法:slideDown(),slideUp(),slideToggle()1、jQueryslideDown()方法用于向下滑动元素。$(selector).slideDown(speed,callback);可选的speed参数规定效果的时长。它可以取以下值:"slow"、"fast"或毫秒。可选的callback参数是滑动完成后所执行的函数名称
一、宽度和高度获取宽度.width()描述:为匹配的元素集合中获取第一个元素的当前计算宽度值。这个方法不接受任何参数。.css(width) 和 .width()之间的区别是后者返回一个没有单位的数值(例如,400),前者是返回带有完整单位的字符串(例如,400px)。当一个元素的宽度需要数学计算的时候推