网站首页 > 教程分享 正文
前言
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)
精彩评论
最后
每天发布更多新鲜有含量的技术文章、总有一款适合你。
快关注我、把我打包带走、每天提醒你学习一手技术。
猜你喜欢
- 2024-10-17 jQuery基础教程学习笔记(九)常用工具函数(最后一节)
- 2024-10-17 用原生 JavaScript 实现十大 jQuery 函数
- 2024-10-17 如何批量删除新浪微博内容?(新浪微博app怎么批量删除微博)
- 2024-10-17 jQuery 遍历- 过滤(jquery遍历li)
- 2024-10-17 4、JQuery 的常用的方法增、删、复制、改、查(必会)
- 2024-10-17 竟然还在更新?jQuery 3.6.1 更新发布
- 2024-10-17 那些年,我们一起"追"过的Jquery
- 2024-10-17 重走JAVA编程路,DOM操作的强大封装类库:Jquery
- 2024-10-17 jQuery事件的解绑和触发(jquery中绑定和解绑的事件有哪些)
- 2024-10-17 前端讨论 - 你是否还需要jQuery(党支部委员会讨论是否确定为发展对象的意见)
你 发表评论:
欢迎- 最近发表
-
- 有了这份900多页的Android面试指南,你离大厂Offer还远吗?
- K2 Blackpearl 流程平台总体功能介绍:常规流程功能
- 零基础安卓开发起步(一)(安卓开发入门视频)
- 教程:让你的安卓像Windows一样实现程序窗口化运行
- Android事件总线还能怎么玩?(事件总线有什么好处)
- Android 面试被问“谈谈架构”,到底要怎样回答才好?
- Android开发工具Parcel和Serialize
- Android 中Notification的运用(notification widget安卓)
- Android退出所有Activity最优雅的方式
- MT管理器-简单实战-去除启动页(mt管理器怎么去除软件弹窗)
- 标签列表
-
- css导航条 (66)
- sqlinsert (63)
- js提交表单 (60)
- param (62)
- parentelement (65)
- jquery分享 (62)
- check约束 (64)
- curl_init (68)
- sql if语句 (69)
- import (66)
- chmod文件夹 (71)
- clearinterval (71)
- pythonrange (62)
- 数组长度 (61)
- javafx (59)
- 全局消息钩子 (64)
- sort排序 (62)
- jdbc (69)
- php网页源码 (59)
- assert h (69)
- httpclientjar (60)
- postgresql conf (59)
- winform开发 (59)
- mysql数字类型 (71)
- drawimage (61)
本文暂时没有评论,来添加一个吧(●'◡'●)