2018前端工程師成長路線圖

来源:https://www.cnblogs.com/fundebug/archive/2018/09/04/2018-frontend-roadmap.html
-Advertisement-
Play Games

譯者按: 上王者算什麼?有本事刷一下你的前端技術! 原文 : "Modern Frontend Developer in 2018" 譯者 : "Fundebug" 為了保證可讀性,本文采用意譯而非直譯。另外,本文版權歸原作者所有,翻譯僅用於學習。 過去5年, "我" 一直作為一枚 全棧工程師 ,經 ...


譯者按: 上王者算什麼?有本事刷一下你的前端技術!

為了保證可讀性,本文采用意譯而非直譯。另外,本文版權歸原作者所有,翻譯僅用於學習。

過去5年,一直作為一枚全棧工程師,經常會有小朋友問我應該學什麼,於是我寫了這篇博客,希望可以幫助大家。本文的所有圖表都在我的GitHub倉庫kamranahmedse/developer-roadmap

下圖是我給前端工程師制定的成長路線圖(由Fundebug翻譯),希望對大家有所幫助:

成為前端工程師,第一步應該是學習HTML/CSS/JavaScript,這是基礎。

1. HTML

HTML用於定義網頁的結構。你的第一步是學習HTML的語法,學會如何把頁面拆分為多個部分。

任務: 至少擼5個純HTML頁面,你可以實現任意網站的頁面,比如GitHub的profile頁面或者Twitter的登陸頁面。純HTML會有點醜,但是不用擔心,專註於網頁的結構。

2. CSS

CSS,全稱Cascading stylesheets,是用來美化HTML頁面的

  • 學習CSS語法,並且熟悉CSS的常用屬性。
  • 學習Box Model,學會使用Grid和Flexbox佈局。
  • 學會使用Media Queries來實現響應式佈局。

任務: 使用CSS美化第1步中實現的HTML頁面。如果你實現的HTML是GitHub的profile頁面,那你現在就可以使用CSS讓它看起來更像實際頁面。

3. JavaScript

JavaScript為靜態頁面添加交互性。比如網站的所有彈框、提醒,以及更新頁面的部分內容,都是由JavaScript實現的。

  • 學習JavaScript的基本語法。
  • 學習如何使用JavaScript操作DOM元素。比如,如何刪除、添加頁面元素等。
  • 理解作用域、閉包、變數提升等JavaScript難點。
  • 學習使用XHR和Ajax發起HTTP請求。
  • 學習JavaScript最新標準ES6。

是否需要學習JQuery? No!

很久以前,大家熱愛JQuery,因為它封裝了JavaScript的介面,讓我們可以不用考慮瀏覽器相容性。但是,JQuery的時代已經過去了,新的項目已經很少用它了。因此,你不需要學習JQuery了!。要知道,GitHub已經完全移除jQuery了!但是,仍然有人在使用JQuery,它很簡單,瞭解一下就好了。

4. 使用HTTM/CSS/JavaScript寫一個網站

學習編程的最佳方式是敲代碼。既然你已經學會了HTTM/CSS/JavaScript,那你就可以寫一個簡單的網站了,比如個人博客。記住,你可以去複製他人的代碼,但是你需要儘量使用你所學到的所有知識點。前端工程師都應該有個人網站,至少有個靜態網站!

5. 為GitHub項目提PR

是時候做一些正真的事情了!到GitHub找一些前端項目,提一些PR。下麵我提供一些思路:

  • 優化UI
  • 解決issue
  • 重構代碼

GitHub是一個非常好的學習和交流的平臺,試著為開源社區做一點點貢獻吧!現在已經有人開始花錢在GitHub買賬號,買項目,買Star,這是一件很無聊的事情,嚴重敗壞了社區風氣,請大家一起抵制!

6. 包管理器

如果你不使用包管理工具的話,當你需要使用第三方插件時,需要手動下載JavaScript或者CSS文件,將它們放進你的項目;這些插件更新時,你又得重新下載文件,這非常麻煩。

如果你使用包管理工具,比如npm或者yarn時,一切就方便很多了。它們可以幫助第管理所有第三方庫,更新也很方便。另外,NPM和YARN基本沒什麼區別,你可以選擇任意一個。

7. 使用NPM或者YARN模塊

不要重覆造輪子,第三方模塊極大豐富了前端開發的生態系統,我們應該學會好好利用。你可以為第4步中開發的網站添加一些第三方模塊,比如使用moment處理時間,使用echarts畫圖表。

8. CSS預處理器

CSS預處理器,例如Sass,Less和Stylus,可以增強CSS的功能,比如支持變數、計算以及函數等。如果讓我選擇的話,我會選擇Sass。最近,PostCSS開始變得流行起來,它確實還不錯,相當於CSS的Bable。你可以單獨使用PostCSS或者基於Sass使用。我建議你先學習Sass,有時間再瞭解一下PostCSS。

9. CSS框架

目前,最流行的CSS框架是Bootstrap、Materialize和Bulma。如果非要選一個最流行的,那我覺得是Bootstrap。

各位前端大俠,歡迎免費試用Fundebug的實時BUG監控服務,闊以幫你快速發現線上BUG哈!

10. CSS規範

對於大型前端項目,CSS會變得非常混亂,難以維護,需要使用規範。我們有多種方式來組織CSS,比如OOCSS、SMACSS、SUITCSS、Atomic和BEM。你應該瞭解一下它們之間的不同,個人更加偏好BEM

11. 構建工具

構建工具指的是開發前端項目用到的代碼校驗工具(linter)任務管理工具(task runner)打包工具(bundlers)

代碼校驗工具有ESLint、JSLint、JSHint和JSCS。目前ESLint是最受歡迎的。

任務管理工具有npm script、gulp和Grunt等。現在,webpack可以完成任務管理工具的大部分工作,因此我們可以結合npm script和webpack一起使用就好了。

打包工具有Webpack、Rollup、Browserify。我推薦大家使用Webpack。Rollup也很常見,不過通常用於打包第三方庫。

12. 開發一個NPM模塊

恭喜!你已經是個75%的前端工程師了!現在,你要做的事情是開發一個真正有用的東西。比如,你可以寫一個NPM模塊,把它開源到GitHub併發布到NPM。編程過程中難免遇到一些問題,需要自己造一些輪子,你要做的就是把輪子造好一點,發佈出來就好了。優秀的工程師不僅要參與開源項目,還應該創造並維護自己的開源項目,哪怕是一個小小的工具。還是那句話,不要去花錢買項目,那是騙自己玩的。

13. 前端框架

在其他人的學習計劃中,會把前端框架放在HTML/CSS/JavaScript之後。但是,我覺得你需要先瞭解一下Sass、構建工具和包管理工具,這些在框架中都會用到,如果你知道他們,大概會被嚇到...

目前,最流行的前端框架有React、Vue和Angular,你可以選擇任意一個,都沒啥毛病。如果是我的話,我會選擇React或者Angular。

如果你是初學者,你也許會發現Angular更簡單,它把所有需要的東西都給你弄好了,比如路由功能(支持懶載入)、HTTP客戶端(支持攔截器)、依賴註入等,這樣你就不需要去使用第三方庫了。對於React,你就需要使用很多第三方庫。兩者各有優劣吧。

框架對比是個很大的話題,這裡我就不多說了。我們可以簡單對比一下Angular和React的學習曲線:

如果你選擇了一個框架,意味著你必須學習一些特定的技術。對於React,你需要學習Redux或者Mobx來進行狀態管理。至於選擇Redux還是Mobx,取決於應用的大小。Mobx適合中小型應用,而Redux適於大型項目。對於Angular,你需要學習TypeScript和Rx.js。而對於Vue.js,你需要學習Vuex,相當於Redux。

14. 使用框架開發一個網站

現在,你已經掌握了現代前端開發所需要的所有技術。那就使用你選擇的框架開發一個應用吧!當然,現在前端項目基本上都是框架開發的...

當你開發完之後,學習一下如何衡量和優化性能,比如你可以關註一下Interactivity Time, Page Speed Index和Lighthouse Score。

15. 測試

對於前端測試,有很多不同的工具,比如Jest、Mocha、Karma和Enzyme,在你學習測試工具之前,請先理解測試的價值,並瞭解一下測試的分類。推薦讀一下這些博客:

16. Progressive Web Apps

學習一下Service WorkerProgressive Web Apps

17. 靜態類型檢查

為JavaScript添加靜態類型檢查,可以讓代碼更加嚴謹,避免很多錯誤。你只要學習數個小時,就可以一直受益。TypeScript和Flow是兩種不同的JavaScript靜態類型檢查技術。

TypeScript重新制定一套支持類型檢查的語言,編譯為JavaScript代碼來運行。

Flow是一種靜態類型檢查工具,可以在編碼時檢查到類型錯誤並做出提示。

因此,TypeScript更強大,難度更大,尤其是重構成本很高;而Flow功能和使用都很簡單,基本上基本上夠用。你可以根據需要進行選擇。

18. 服務端渲染

服務端渲染,即Server Side Rendering,又稱為後端渲染。其實就是服務端先把HTML頁面填充數據之後,再返回給前端。這樣做可以提升首屏性能,有助於SEO,減少客戶端用電。

對於不同的前端框架,有不同的服務端渲染技術。React有Next.jsAfter.js,Angular有Universal,Vue.js有Nuxt.js

但是,是否採用服務端渲染其實還有爭議,瞭解一下可以,是否根據需要決定是否使用。

19. 其他技術

作為一個專業的前端工程師,學習一下canvas、HTML5、SVG、Source Map、函數式編程、TC39等技術還是非常有必要的!

參考博客

關於Fundebug

Fundebug專註於JavaScript、微信小程式、微信小游戲、支付寶小程式、React Native、Node.js和Java實時BUG監控。 自從2016年雙十一正式上線,Fundebug累計處理了6億+錯誤事件,得到了Google、360、金山軟體等眾多知名用戶的認可。歡迎免費試用!

版權聲明:
轉載時請註明作者Fundebug以及本文地址:
https://blog.fundebug.com/2018/08/30/ecmascript-regular-expression-new-features/


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 註意: 有的Centos版本預設安裝了mariadb, 可以先將其卸載 檢查mariadb是否安裝 yum list installed | grep mariadb 卸載mariadb( all ) yum -y remove mariadb* 1. 網上下載MySQL的yum源 wget htt ...
  • 今日內容介紹 1.MySQL資料庫 2.SQL語句 01資料庫概念 A: 什麼是資料庫 資料庫就是存儲數據的倉庫,其本質是一個文件系統,數據按照特定的格式將數據存儲起來, 用戶可以對資料庫中的數據進行增加,修改,刪除及查詢操作。 B: 什麼是資料庫管理系統 資料庫管理系統(DataBase Mana ...
  • 一、簡介 pt-query-digest是用於分析mysql慢查詢的一個工具,它可以分析binlog、General log、slowlog,也可以通過SHOWPROCESSLIST或者通過tcpdump抓取的MySQL協議數據來進行分析。可以把分析結果輸出到文件中,分析過程是先對查詢語句的條件進行 ...
  • 1、平臺: Windows10 Pycharm 2018.1 Python 3.6.4 2、問題: 我在Pycharm下建立一個flask_ab工程,導入包: 運行時報錯:“ImportError: No module named flask_sqlalchemy” 3、解決方案: 打開File-> ...
  • 字元串作為OC語言的基本對象類型,被我們在各種地方廣泛使用,因此熟悉掌握字元串的屬性和方法,是OC必不可少的基礎之一。 字元串分為可變字元串(NSMutableString)和不可變字元串(NSString),首先我們來學習不可變字元串的屬性與方法。 一、不可變字元串 1.創建不可變字元串 主要有四 ...
  • 觀察者模式的概念 觀察者A與被觀察者B建立訂閱關係,當被觀察者B發生某種改變時,立即通知觀察者A 添加依賴 基本模式 Observable被觀察者 註意各地方添加泛型避免大片警告,onNext()是事件的回調,onComplete()是事件的結尾。onComplete()與onError互斥需要保持 ...
  • 在Android 編程中經常會用到Uri轉化為文件路徑,如我們從相冊選擇圖片上傳至伺服器,一般上傳前需要對圖片進行壓縮,這時候就要用到圖片的絕對路徑。 下麵對我開發中uri轉path路徑遇到的問題進行總結,其中涉及到Android不同api下對於uri的處理,還有對於Google相冊圖片該如何獲取其 ...
  • Fragment生命周期 Fragment比Activity多的生命周期 Fragment引入佈局 重寫onCreateView方法引入佈局 Fragment事務 1.基本方法 使用事務之前,需要先獲取FragmentManager Fragment的回退棧 通過Activity維護一個回退棧來保存 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...