|
|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
前两天看到 jQuery 4.0 发布 Beta 版的消息:
第一反应也是:“这项目居然还在更?”
顺手点开 Changelog 扫了一眼,发现这次不太一样。
这位 Web 开发界的“活化石”,干了一件它早就该干、但一直没舍得干的事:
不再支持IE10,并且,逐步移除对IE和老旧浏览器的支持
这个东西,是一个JS库,但凡了解过前端开发的同学,绝对不陌生的。
不知道的鱼油也没关系,你知道这是一个重要的库就行了,至于有多重要呢,可以说是几乎所有网站都用过。
小甲鱼老师Web课程:
现在的入行的新人可能很难共情这种感觉。
在他们的世界里,浏览器基本等于 Chrome,顶多再测个 Safari,火狐路边一条。
但是,把时间倒回20年前,哦不,是10年前。
前端开发约等于“和 IE 斗智斗勇”。
你刚写好一个酷炫的布局,在 Chrome 上完美运行,一开 IE,全乱套了。
为了调一个 z-index 的层级 bug,或者修一个 opacity 的透明度问题,你得写一堆丑陋的 hack 代码。
那时候,$ 符号不是一个库,它是我们的
jQuery 最牛的地方,不是有什么惊天动地的算法,而在于代码一致性,它帮我们挡住了浏览器那些稀奇古怪的差异。
它那句 Write Less, Do More,翻译过来其实是:
同时,这个库,也大幅度精简了当时前端开发的难度,一句顶10句。
比如说,给网页做一个,点击按钮,元素切换的功能。
jQuery一句话搞定
- $("#btn").on("click", () => $("#panel").stop(true, true).slideToggle(200));
复制代码
而使用原生,需要先找到元素,再找到面板,再绑定事件,再切换样式。
并且,还得添加css样式的代码:
- const btn = document.querySelector("#btn");
- const panel = document.querySelector("#panel");
- btn.addEventListener("click", () => {
- panel.classList.toggle("open");
- });
- //还需要加点css
- #panel { max-height: 0; opacity: 0; overflow: hidden; transition: .2s; }
- #panel.open { max-height: 200px; opacity: 1; }
复制代码
当然,可能用得更多的,还是发送http请求了!
比如发一段post,jQuery还是一句话:
- $.post("/api/login", { user: "a", pass: "b" }, (res) => console.log(res));
复制代码
原生JS,如果浏览器支持fetch还好,但是IE这个是不支持的,所以写起来要命:
- var xhr = new XMLHttpRequest();
- xhr.open("POST", "/api/login", true);
- xhr.setRequestHeader("Content-Type", "application/x-www-form-urlencoded");
- xhr.onreadystatechange = function () {
- if (xhr.readyState === 4 && xhr.status === 200)
- { console.log(JSON.parse(xhr.responseText)); }};
- xhr.send("user=a&pass=b");
复制代码
所以嘛,jQuery 几乎是所有网页必备的库,就算到了现在,市场占有率,同样是居高不下。
这次更新,它终于支持 ESM 模块化了。
这意味着你终于不用像十几年前那样,在 <script> 标签里排队引入文件了。
你可以像用 React 或 Vue 一样,优雅地 import 它,把它塞进现代的构建流程里,让jQuery继续发光发热。
那么问题来了:
按理说,现在的原生 JS (querySelector, fetch, classList) 已经够好用了,React 和 Vue 更是统治了复杂的应用开发。
jQuery 看起来确实像个上个时代的残党。
在外网看到一个观点,说的是:
有时候只是想做一个简单的活动页,或者给 WordPress 写个插件,却被逼着去配Vite、 Webpack、去配 TypeScript、去思考组件的生命周期……
有时候,前端程序员只是想让这一行字淡入淡出而已
这可能就是为什么,直到今天,W3Techs 的数据显示全网还有 88% 的网站在使用 jQuery。
所以,jQuery还在更新,还想继续为大家提供支持,随时准备为那些需要简单粗暴解决问题的人提供一把趁手的瑞士军刀。
评论区聊聊你的想法吧
如果有收获,别忘了评分 :
|
|