前端发展很快,现代浏览器原生 api 已经足够好用。我们并不需要为了操作 dom、event 等再学习一下 jquery 的 api。同时由于 react、angular、vue 等框架的流行,直接操作 dom 不再是好的模式,jquery 使用场景大大减少。因此我们项目组在双十一后抽了一周时间,把所有代码中的 jquery 移除。下面总结一下:
why not jquery1. 模式变革
jquery 代表着传统的以 dom 为中心的开发模式,但现在复杂页面开发流行的是以 react 为代表的以数据/状态为中心的开发模式
应用复杂后,直接操作 dom 意味着手动维护状态,当状态复杂后,变得不可控。react 以状态为中心,自动帮我们渲染出 dom,同时通过高效的 dom diff 算法,也能保证性能。我们在 react 应用实践中也发现,大部分当你想直接操作 dom 的时候,就意味着你可能做错了。
2. 不支持同构渲染
重构就是前后端运行同一份代码,后端也可以渲染出页面,这对 seo 要求高的场景非常合适。由于 react 等流行框架天然支持,已经具有可行性。当我们在尝试把现有应用改成同构时,因为代码要运行在服务器端,但服务器端没有 dom,所以引用 jquery 就会报错。这也是要移除 jquery 的迫切原因。同时不但要移除 jquery,在很多场合也要避免直接操作 dom。
3. 原生 api 足够好用
由于浏览器的历史原因,曾经的前端开发为了兼容不同浏览器怪癖,需要增加很多成本。jquery 由于提供了非常易用的 api,屏蔽了浏览器差异,极大地提高了开发效率。这也导致很多前端只懂 jquery。其实这几年浏览器更新很快,也借鉴了很多 jquery 的 api,如 queryselector,queryselectorall 和 jquery 选择器同样好用,而且性能更优。
4. 性能
前端开发一般不需要考虑性能问题,但你想在性能上追求极致的话,一定要知道 jquery 性能很差。原生 api 选择器相比 jquery 丰富很多,如 document.getelementsbyclassname 性能是 $(classselector) 的 50 多倍!
测试链接:http://jsperf.com/jquery-vs-native-api
5. 时机成熟
差的浏览器(ie)已经淘汰的差不多了。
if we didn’t spend so much on ie support, we could be taking vacations on mars
christian alfoni
我们的主打产品现在有千万用户,因为我们一直引导用户升级浏览器,上个月统计 ie 9 以下用户只占不到 3%。但为了这 3% 的用户我们前端开发却增加了很多工作量,也限制了我们升级我们的架构,因此放弃支持他们利大于弊。当然这要根据产品来定,比如这是百度统计的国内浏览器占有率,ie8 竟然还有 22%。有些产品可以为了保证用户体验,在旧的浏览器上投入很大成本,甚至做到了极致。其实我觉得产品更应该做的是引导用户升级浏览器。微软也宣布 2016年1月12号停止支持 ie 11 以下浏览器,继续使用旧浏览器就会有安全风险,我们更应该主动引导,只要产品有足够吸引力,大部分用户升级并不困难。
数据来源 百度统计
下面是国际上 ie 占有率,ie8 已经跌出前 10,ie 11 比较多,还好支持他们并不难。
数据来源 w3 counter
如何移除 jquery1. 替换代码
移除 jquery 可以很顺利,我们把整个过程详细整理了,并开源。
打开 https://github.com/oneuijs/you-dont-need-jquery 对 api 查找替换即可。
同时我们简单封装了一些方法:
oui-dom-utils 来做选择器和样式相关
oui-dom-events 来做 event,支持命名空间和事件代理
刚去了 jquery 又引了新的库,这不是玩我吗其实以上两个库很简单,只是常用方法的简单封装,建议你看一下代码。你当然可以不用。
以上的库都用于我们的生产环境,我们会长期维护,保证更新。
2. 旧浏览器自动跳转
代码替换后,当用户用旧浏览器打开时,你还要做一个跳转,把用户定位到提示页面,提示用户下载升级浏览器。ie9 以下浏览器都支持条件判断语句,可以在 </head> 标签结束前添加如下代码做自动跳转
<!–[if lte ie 9]>
<script>if (!/update\.htm/.test(location.href)) window.location = ‘//abc.com/update.htm’; </script>
<![endif]–>
总结
本文并不是强迫你一定要移除 jquery,jquery 为支持旧浏览器节省了很多成本。但条件成熟的情况下,移除 jquery,参照 you don’t need jquery 拥抱原生 javascript 能同样保证开发效率,也可以给产品带来更好的性能,同时也能提高开发者水平。
原发于我的博客,原文地址:https://github.com/camsong/blog/issues/4
转载:http://segmentfault.com