GitHub Dashboard 重构放弃使用 jQuery
开源中国
公众号ID:oschina2013
关注
作者:徐川
转自:前端之巅(frontshow)
GitHub 近日进行了改版,除了界面的修改,GitHub 的前端团队还乘机移除了页面中的 jQuery:
值得一提的是,GitHub 前端团队并未使用其它框架来代替 jQuery,而是使用原生 JS:
用 querySelectorAll 来查询 DOM 节点;
使用 fetch 代替 ajax(在不支持的浏览器上使用 XHR);
使用代理事件来进行事件处理;
为一些尚未实现的 DOM 标准写了 polyfill;
更多的使用自定义元素(CustomElement)。
他们把其中的一些成果也在 GitHub 上开源了:
Fetch polyfill:
https://github.com/github/fetch
Delegated events:
https://github.com/dgraham/delegated-events
Custom Elements:
https://github.com/search?q=topic%3Aweb-components+org%3Agithub
jQuery 曾风靡一个时代,大大降低了前端开发的门槛,丰富的插件也是前端开发者得心应手的武器库,但是,这个时代终于要落幕了。随着 JS 标准和浏览器的进步,jQuery 的很多精华被原生 JS 吸收,我们直接使用原生 API 就可以用类似手法来处理以前需要 jQuery 的问题。在新的 Web 项目中,如果不需要支持过于陈旧的浏览器版本,那么的确没有必要使用 jQuery。
但是,像 GitHub 这样重构掉 jQuery 有必要吗?
在微博上,有人指出其实没必要对旧项目进行大改:
对于没有更多需求的项目,的确没有必要大动干戈,但是,GitHub 是一个仍在继续迭代,不断有新功能模块推出的大型项目。通过改版的机会进行重构、切换技术栈,是目前互联网行业比较通常的做法。
在重构的过程中当然会引入新的问题,但如果比较一下收益,比如组件化、工程化的引入,对后续维护、持续的用户体验优化带来的好处,还是值得这么做的。
最后,jQuery 也并不是不能用了,它仍然是开发前端网页的一个选择,至于到底如何抉择,则要看当前场景是否适合了。
开源中国征稿开始啦!
开源中国 www.oschina.net 是目前备受关注、具有强大影响力的开源技术社区,拥有超过 200 万的开源技术精英。我们传播开源的理念,推广开源项目,为 IT 开发者提供一个发现、使用、并交流开源技术的平台。
现在我们开始对外征稿啦!如果你有优秀的技术文章想要分享,热点的行业资讯需要报道等等,欢迎联系开源中国进行投稿。投稿详情及联系方式请参见:我要投稿
JDK 11 特性冻结!最全的 Java 11 API 变更提案一览
大变样,Chrome 新一代 Material Design UI 来袭