摘要:無論是還是,對許多應用來說,這個大小都是完全可以接受的。但是為了不用,放棄向后兼容那我覺得還是用得了。自從年雙十一正式上線,累計處理了億錯誤事件,付費客戶有金山軟件百姓網等眾多品牌企業。
譯者按: 看來 jQuery 還是有一些用武之地的。
原文: Why I"m Still Using jQuery in 2019
譯者: Fundebug
為了保證可讀性,本文采用意譯而非直譯。翻譯僅供學習探討,不代表 Fundebug 觀點。
許多人都在提倡: “直接用原生的 JavaScript 就好了,不需要 jQuery 了”。
You might not need jQuery嘗試告訴我們,擺脫 jQuery 是一件很容易的事情。但是,它的第一個例子恰恰告訴我們用 jQuery 其實也不錯,因為我們寫了 10 行原生的 JavaScript 代碼,其實只需要 1 行 jQuery 代碼就夠了。
很多 JavaScript 的 API,尤其是 DOM 相關的 API,挑戰了我的審美哲學,直白點說,我覺得它們太糟糕了!el.insertAdjacentElement("afterend", other)當然也可以用,但是$(el).after(other)更加簡潔。$()函數也沒那么好看,我沒有特別喜歡,但是它比原生的 API 好太多了。
你們如何獲取某個元素的 sibling 呢?到底用nextSibling還是用nextElementSibling?它們有什么不同?各個瀏覽器分別支持哪個方法?當你忙著去 MDN 查文檔的時候,我直接用 jQuery 的next和prev()就好了。
許多常用的 JavaScript 的標準 API 都挺奇怪的,這里我就不列出來了,大家去You might not need jQuery看看就知道了。
寫代碼的時候,我們總會需要使用一些常用的幫助函數,You might not need jQuery列舉了很多,使用 jQuery 可以很方便的使用這些幫助函數,這樣我們就不需要每次都去 Stack OverFlow 上去復制代碼了。。。
瀏覽器的兼容問題已經沒有以前那么頭疼了,但是它還是個不小的問題,除非你覺得只要 85%的用戶 OK 就行。關于這個問題,大家可以閱讀我的Why Hello CSS doesn’t use CSS variables。
那么,我們必須使用 jQuery 嗎?當然不是!使用任何第三方庫都是有代價的,增加了復雜度,也增加了文件大小。但是,jQuery 其實沒那么大,壓縮之后的大小只有 30K。如果我們去掉 ajax 以及一些不常用的功能的話,就只有 23K;如果我們使用 querySelector 替代 SizzleJS 來構建的話,則只有 17K 了。無論是 30K 還是 17K,對許多應用來說,這個大小都是完全可以接受的。
大家不妨看看Bootstrap removing jQuery,為了移除 jQuery,他們也是花了不少精力啊:自己擼幫助函數;放棄兼容 IE,因為太難寫了;他們花了 1 年半時間來倒騰這個。最終的結果在我看來,這些努力似乎不值得。
我理解他們為什么這么做,大家希望在 Vue 項目中使用 Bootstrap,但是同時使用 Vue 和 jQuery 的話有點傻。對于減少網頁大小,我非常同意,也很喜歡Web bloat與The Ethics of Web Performance兩篇博客中的觀點。但是,我們需要實際一點,不要過于理想主義。添加 17K 的 jQuery 真的那么糟糕嗎?當我吐槽 Medium 或者 New York Times 這樣的網站需要的 JS 文件超過 1M 的時候,有的人會這樣反駁:”莫非你還在用 56k 的帶寬?“,但是,為什么 17K 的 jQuery 就那么不能接受了呢?
不用 jQuery 而自己寫幫助函數也可以,比如你希望你寫的函數被其他人復用,或者你寫的函數特別小。但是為了不用 jQuery,放棄向后兼容?那我覺得還是用 jQuery 得了。所有事情都用 jQuery 實現當然不好,但是任何時候都不用 jQuery也不是什么明智之舉。
我不是 jQuery 的狂熱粉絲,我也愿意使用一些簡化版的 jQuery,只要它們可以讓 JS 的 API 更好用一點。You might not need jQuery推薦了bonzo和$dom,以及其他一些 AJAX 庫,但是大多數看起來沒怎么維護。如果沒有足夠吸引人的理由,最好不要去替代 jQuery,因為 jQuery 本身沒什么大毛病。
有些讀者也許會去比較 Vue, React 以及其他前端框架,但是這篇博客的目的是比較 jQuery 與原生的 JavaScript,沒有打算去論證整個前端到底應該如何開發。
話說回來,我覺得有些場景下只使用簡單的 JavaScript 也挺好的,主要原因是我希望網頁可以足夠快,可以讓盡量多的人正常訪問。以我的經驗,使用服務端渲染,再加上漸進式增強 JavaScript,是最佳的實現方式,開發起來很簡單,訪問速度足夠快,BUG 也很少。
難道前端框架不好嗎?當然不是,沒有什么絕對不好的技術,所有技術都有一定的取舍,當然也包括 jQuery。
參考GitHub:我們是這樣棄用jQuery的
為啥jQuery被淘汰了?
為什么越來越少的人用jQuery
關于FundebugFundebug專注于JavaScript、微信小程序、微信小游戲、支付寶小程序、React Native、Node.js和Java線上應用實時BUG監控。 自從2016年雙十一正式上線,Fundebug累計處理了10億+錯誤事件,付費客戶有Google、360、金山軟件、百姓網等眾多品牌企業。歡迎大家免費試用!
版權聲明轉載時請注明作者Fundebug以及本文地址:
https://blog.fundebug.com/2019/06/04/why-i-am-still-using-jquery-in-2019/
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/104391.html
摘要:類似,是由,和個人開發者和公司的社區維護。這是非常流行的用于設計網站和應用程序的開源前端框架。這是另一個日益普及的大數據框架。最初是由創建的另一個移動應用程序開發框架。在年收購了,將其重新命名為,后來又發布了一個名為的開源軟件。 春節即將來臨,許多開發者們已經做好了新一年的學習計劃,假如你還沒有計劃好2018年,可以看下這一篇文章,在這篇文章中,我將分享一些值得開發者學習的優秀框架,以...
摘要:時光飛逝,歲月如梭,我從前端開發崗位轉入測試崗位已經三年了,這期間從迷茫到熟悉,到強化,到熟練,到總結,感受還是很深的三年前的某一個晚上,我正準備下班回家,我們的項目經理把我叫到辦公司和我談話,談了很多,具體說什么不記得 ...
摘要:很多程序員問我,感覺漲工資不再像以前那么簡單了,感覺現在很迷茫。這也是很多用人單位喜歡高學歷的學生。類學生一般是工作年以內,或者培訓以后年以內,這類人優點是專業技能上身快,學習有針對性,效率高。這個是最重要的,也是很多人不成功的原因。 showImg(https://segmentfault.com/img/bVbgTka?w=1080&h=608);很多程序員問我,感覺漲工資不再像以...
摘要:很多程序員問我,感覺漲工資不再像以前那么簡單了,感覺現在很迷茫。然后換了第二份工作,工資也漲到了。目前基礎如何,對技術鏈條把我的長短。這個是最重要的,也是很多人不成功的原因。很多人喜歡打嘴炮,說的很好計劃很合理,沒堅持兩天又放棄了。 showImg(https://segmentfault.com/img/bVbgTka?w=1080&h=608);很多程序員問我,感覺漲工資不再像以前...
摘要:很多程序員問我,感覺漲工資不再像以前那么簡單了,感覺現在很迷茫。這也是很多用人單位喜歡高學歷的學生。類學生一般是工作年以內,或者培訓以后年以內,這類人優點是專業技能上身快,學習有針對性,效率高。這個是最重要的,也是很多人不成功的原因。 showImg(https://segmentfault.com/img/bVbgTka?w=1080&h=608);很多程序員問我,感覺漲工資不再像以...
閱讀 2097·2023-04-26 00:09
閱讀 3115·2021-09-26 10:12
閱讀 3481·2019-08-30 15:44
閱讀 2863·2019-08-30 13:47
閱讀 922·2019-08-23 17:56
閱讀 3226·2019-08-23 15:31
閱讀 474·2019-08-23 13:47
閱讀 2508·2019-08-23 11:56