作者簡介:aoto 螞蟻金服·資料體驗技術團隊
以下我說的都是個人觀點,比較巨集觀粗淺,主要針對的是前端工程師本身,沒有深入技術和業務細節,請謹慎參考。
職能概覽
前端工程師首先是個程式設計師,其次也是個軟體工程師,他們工作在離使用者最近的地方,負責人機互動和使用者體驗,雖然叫“前端”,但其實他們的工作邊界其實已經很寬了。展望未來,我想前端的工作會繼續分化,也會繼續融合,分工是工業革命以來社會高效協作的主要推動力,以後很長一段時間應該也會維持這種形態,融合的原始推動力也是提高效率。分化和融合是不斷的演化和互吸收轉化的,不過核心的東西我想還是不會有太大變化。
觀點
- 繼續分化(領域、行業、技術棧)
- 繼續融合(端技術、Web全棧技術、人工智慧與端技術)
- 核心不變(電腦科學本質、軟體工程思想與實踐、程式設計師職業素養)
1. 繼續分化
領域
前端領域會繼續分化,例如阿里內部的前端就已經有中後臺、圖形、端技術、泛Node、開發者服務5個大方向了,每個大方向也會細分,舉一些例子:
- 中後臺:有云控制檯、資訊&資產管理平臺、內部研發&專案管理平臺、人工智慧&機器學習平臺、資料研發分析平臺,企業內部資訊平臺等。具體產品如阿里雲控制檯、ERP、PAI、DeepInsight、阿里內外、Basecamp等。
- 圖形:有基礎圖形庫、3D圖形、資料視覺化、流程圖等。具體產品如G2、DataV、阿里雲城市大腦、滴滴智慧交通排程圖、雙十一大屏等。
- 端技術:有移動端(iOS、Android、MobileWeb、PWA、小程式)、PC端(客戶端、Web端)、觸屏電腦、各種監控大屏、智慧手錶手環,智慧汽車&家居螢幕等。具體產品如淘寶支付寶的App、PC主站、移動H5站,阿里郎、VS Code、雙十一大屏、UC瀏覽器UWP版本、各種智慧手錶、手環、汽車、家居螢幕等。
- 泛Node:有工具鏈、Web框架、IoT、客戶端(Electron、NW)等。具體產品如DEF/Atool/F2E-Test(阿里前端開發者工具)、Egg.js、阿里雲的IoT應用、VS Code等。
- 開發者服務:有應用開發運維平臺、元件市場等。具體產品如阿里雲的應用搭建平臺Boat、Fusion-Design元件市場,支付寶小程式開發者工具等。
- ...
行業
- 2B
- 資訊管理、財務、建築、航天、水利、金融、製造等傳統行業軟體以及阿里提出的五新:新零售,新制造,新金融,新技術和新能源,新技術賦能傳統行業
- SAAS軟體及服務:如Teambition、Trello、釘釘企業版、Basecamp、Growing.io
- 2C
- 移動App:如微信、微博
- PC工具應用:如Google Doc
- 產品展示類網站:如阿里雲、支付寶官網
- ...
技術棧
- React(Native)
- Angular(NativeScript)
- Vue(Weex)
- ...
2. 繼續融合
端技術
-
前端、客戶端技術思想的融合
- 元件化(元件化搭建頁面)
- 元件生命週期鉤子函式(如iOS ViewController)
- MV*(如MVVM設計就來源於微軟客戶端開發框架)
-
大前端的統一
- 虛擬DOM技術:React/ReactNative/ReactCanvas
- 各種移動裝置核心和引擎的統一:WebKit/V8
- Web技術文件的統一:Mozilla Web Docs
Web全棧技術
- 前端、後端技術思想的融合
- MV*(如前端的第一個MVC框架Backbone.js就來自於Ruby on Rails開發者)
- AOP、依賴注入(Angular)
- GraphQL(SQL)
- IndexedDB(Database)
- ...
人工智慧與端技術
- 人工智慧、前端技術的融合
- 端是最終觸達使用者的節點
- 端資料採集->後端機器學習、資料分析->智慧推薦呈現
- 物聯網、前端技術的融合
- 智慧家居/汽車/工業裝置可能是有螢幕的,同時可以基於如JerryScript這樣的JS執行引擎使用Node.js開發聯網應用
3. 核心不變
也就是電腦科學本質/軟體工程思想與實踐/程式設計師職業素養。這個就不是一段文字可以涵蓋的了,這裡不做詳細論述。
歷史回顧
回顧過前端的演化,主要參見最底下的相關資源,下圖簡要回顧一下95年以來軟體開發和前端歷史:
前端的未來
那些生存空間越來越小的產業
有一些切分體會
- 小規模移動App:移動App市場被一些巨頭把持,小規模App生存空間越來越小
- PC資訊導航類網站(網址、購物、論壇、生活):現在移動優先,而且有智慧推薦,並且是強社交
無介面互動
Web前端能做一些事,主要是大前端的範疇
- 會話式介面(視訊語音會話、語音搜尋:WebRTC,開源語音庫:Common Voice)
- 感官式介面(視覺:WebAR/WebVR)
- 無介面,未來會有大量IoT裝置(IoT有自己的通訊協議和規範,前端的工作是在使用者看不見的後臺)
富介面互動
大量工作需要前端來做
- 日常辦公軟體(複雜應用,並且慢慢從桌面程式演化為Web):Office、Email、文件管理、產品設計、專案管理、程式碼編輯器
- 大資料/AI配套軟體(複雜應用,並且慢慢從桌面程式演化為Web):需要大量的後臺系統來做資料分析/機器學習
- 播放器/遊戲:H5代替Flash,如Web Audio、Web Video、Canvas
- 容器/DSL/核心/小程式:支付寶/微信/釘釘容器,核心(也就是UC、QQ瀏覽器核心),及其自定義DSL(如果將來手機的底層能力都可以上浮到小程式,很有想象空間)
- 產品資訊展示類網站(炫酷應用):各種智慧裝置官網、大企業官網
未來在哪裡
回顧觀點
- 繼續分化(領域細分、行業細分、技術棧細分)
- 繼續融合(端技術融合、Web全棧、人工智慧與端技術的融合)
- 核心不變(電腦科學本質、軟體工程思想與實踐、程式設計師職業素養)
一些建議
- 關心人工智慧的發展,思考TA在前端領域可能產生的應用場景
- 視覺稿自動生成程式碼
- 根據使用者使用習慣自動排出最符合該使用者習慣的介面
- 收集使用者資料在前端實時做學習和分析,如deeplearn.js
- ...
- 相信前端的未來,Web的力量
- WebKit
- V8
- Flexbox:Yoga
- ...
- 結合公司業務特點有重點的關注前端的某些方面,畢竟技術服務於業務
以上都是個人觀點。
相關資源
- Web開發這十年:http://www.infoq.com/cn/articles/web-development-ten-years
- GUI應用架構十年變遷:https://segmentfault.com/a/1190000006016817
- 大話前端時代一:https://halfrost.com/vue_ios_modularization/
- 寫給初學前端工程師的一封信:https://zhuanlan.zhihu.com/p/28536429
- 母雞與前端工程師:http://www.ruanyifeng.com/blog/2016/07/hen-and-front-end-engineer.html
- 李開復人工智慧預言:http://tech.sina.com.cn/it/2017-05-20/doc-ifyfkqks4361454.shtml
- 《無介面互動》:https://book.douban.com/subject/26947799/
後記:前端的發展超出了所有人的想象力,未來肯定是難以預測的,也沒有做預測的必要,我們要做的還是踏實做好眼前的事情,“過往不戀、當下不雜、未來不迎”,與君共勉!
對我們團隊感興趣的可以關注專欄或者傳送簡歷至'tao.qit####alibaba-inc.com'.replace('####', '@'),歡迎有志之士加入~