兩個能力:
1、基礎編程能力
js與一門后臺語言,做到熟練運用,同時對于瀏覽器原理也有一些了解。這個的基礎又是算法和數(shù)據(jù)結(jié)構。如果你不懂js熟悉其他也沒問題。
2、學習能力
新技術能很快適應和上手,愿意不斷地學習和探索。這個最主要是好奇心和勤奮。天才一般不存在,只要你有足夠好奇心,并且不斷重復編碼試驗,就會學的快。
其他能力如框架、工具、協(xié)作、工程等等都很快就能掌握。只要有了基礎和意愿,那么去實踐就一定可以達成你的目標。
前端開發(fā)趨勢一直都是熱度高且變化快。因此,對于前端開發(fā)者來說,想要跟上這些不斷變化的趨勢,需要耗費巨大的精力。至于2022年前端技術具體會發(fā)生哪些變化,讓我們一起來聊聊吧。
1、前端介紹
前端,也稱為“客戶端開發(fā)”,簡單來說,你可以在應用程序或網(wǎng)站的屏幕上看到的所有內(nèi)容都屬于前端。讓我們考慮一個現(xiàn)實的例子:你正在訪問的網(wǎng)站。內(nèi)容設計、圖像、段落和線條之間的間距,左上角的公司徽標,以及右下角的小通知按鈕——所有這一切都是前端。2、前端技術包括哪些?
前端開發(fā)是創(chuàng)建Web頁面或app等前端界面呈現(xiàn)給用戶的過程,通過HTML,CSS及JavaScript以及衍生出來的各種技術、框架、解決方案,來實現(xiàn)互聯(lián)網(wǎng)產(chǎn)品的用戶界面交互 。它從網(wǎng)頁制作演變而來,名稱上有很明顯的時代特征。在互聯(lián)網(wǎng)的演化進程中,網(wǎng)頁制作是Web1.0時代的產(chǎn)物,早期網(wǎng)站主要內(nèi)容都是靜態(tài),以圖片和文字為主,用戶使用網(wǎng)站的行為也以瀏覽為主。隨著互聯(lián)網(wǎng)技術的發(fā)展和HTML5、CSS3的應用,現(xiàn)代網(wǎng)頁更加美觀,交互效果顯著,功能更加強大。2.1、HTML
掌握HTML是網(wǎng)頁的核心,是一種制作萬維網(wǎng)頁面的標準語言,是萬維網(wǎng)瀏覽器使用的一種語言,它消除了不同計算機之間信息交流的障礙。因此,它是目前網(wǎng)絡上應用最為廣泛的語言,也是構成網(wǎng)頁文檔的主要語言,學好HTML是成為Web前端開發(fā)人員的基本條件。HTML是一種標記語言,能夠?qū)崿F(xiàn)Web頁面并在瀏覽器中顯示。HTML5作為HTML的最新版本,引入了多項新技術,大大增強了對于應用的支持能力,使得Web技術不再局限于呈現(xiàn)網(wǎng)頁內(nèi)容。隨著CSS、JavaScript、Flash等技術的發(fā)展,Web對于應用的處理能力逐漸增強,用戶瀏覽網(wǎng)頁的體驗已經(jīng)有了較大的改善。不過HTML5中的幾項新技術實現(xiàn)了質(zhì)的突破,使得Web技術首次被認為能夠接近于本地原生應用技術,開發(fā)Web應用真正成為開發(fā)者的一個選擇。HTML5可以使開發(fā)者的工作大大簡化,理論上單次開發(fā)就可以在不同平臺借助瀏覽器運行,降低開發(fā)的成本,這也是產(chǎn)業(yè)界普遍認為HTML5技術的主要優(yōu)點之一。AppMobi、摩托羅拉、Sencha、Appcelerator等公司均已推出了較為成熟的開發(fā)工具,支持HTML5應用的發(fā)展。2.2、CSS
學好CSS是網(wǎng)頁外觀的重要一點,CSS可以幫助把網(wǎng)頁外觀做得更加美觀。2.3、JavaScript
學習JavaScript的基本語法,以及如何使用JavaScript編程將會提高開發(fā)人員的個人技能。2.4、Bootstrap
主流框架之一,Bootstrap 是基于 HTML、CSS、JavaScript的,它簡潔靈活,使得 Web 開發(fā)更加快捷。2.5、html5-boilerplate
該框架可以快速構建健壯,且適應力強的web app或網(wǎng)站。2.6、Meteor
Meteor是新一代的開發(fā)即時web應用的開源框架,它能在較短時間內(nèi)完成開發(fā)。2.7、Semantic UI
基于自然語言有效原則的UI組件框架。2.8、Amaze UI
國內(nèi)首個開源HTML5跨屏前端框架產(chǎn)品系列,中文排版支持更優(yōu)、本土化組件豐富。該產(chǎn)品系列中有專門針對移動端的HTML5混合應用開發(fā)框架Amaze UI Touch以及針對跨屏HTML5網(wǎng)頁開發(fā)的Amaze UI Web。其中,Amaze UI Touch可以幫助開發(fā)者通過豐富的組件,快速構建出與原生APP相媲美的專屬移動端的HTML5應用。3、2022年前端技術領域變化
3.1、Web組件化
基本上這就是未來。為什么?因為這些純Web組件與框架無關,并且可以在沒有框架或沒有任何框架拼寫標準化的情況下工作。因為它們沒有JS疲勞,并且得到了現(xiàn)代瀏覽器的支持。因為它們的文件大小和消耗將是最佳的,并且VDOM渲染令人贊嘆。這些組件提供了Custom Element,這是一個Javascript API,可讓你定義新html標簽,HTML模板以指定布局,當然還有Shadow DOM,它本質(zhì)上是特定于組件的。在這個領域中知名的工具是Lit-html(和Lit-element),StencilJS,SvelteJS,當然還有Bit,它們是可重用的模塊化組件,可以在任何地方直接共享,使用和開發(fā)。考慮組件開發(fā)時代的未來,以及模塊化,可重用性,封裝和標準化的原理,Web組件就是答案。3.2、微前端
Serverless即“無服務器”架構,它試圖幫助開發(fā)者擺脫運行后端應用程序所需的服務器設備的設置和管理工作,它由第三方云計算供應商負責后端基礎結(jié)構的維護,同時以服務的方式為開發(fā)者提供所需的功能,例如數(shù)據(jù)庫、消息、身份驗證等。微前端的概念類似于微服務,它將前端應用拆分成一個個更小的更簡單的能夠獨立開發(fā)、測試、部署的小塊,在用戶看來它依舊是一個獨立的產(chǎn)品。前端業(yè)務在發(fā)展到一定規(guī)模后,需要一種能將業(yè)務化繁為簡的架構。常用的微前端解決方案有single-spa、qiankun。微前端、Serverless目前都未出現(xiàn)大規(guī)模應用的情況,各大公司對此都處于探索階段,兩項技術穩(wěn)步發(fā)展,期待未來大規(guī)模的應用。3.3、微設計
布拉德·弗羅斯特(Brad Frost)提出的理論將Web應用程序的構成與原子,分子,有機體等的自然構成進行了比較,最后以具體的Web頁面作為結(jié)尾。原子由分子組成(例如,文本輸入+按鈕+標簽原子=搜索分子)。分子組成生物體。有機體位于布局模板中,該模板可以具體化為交付給用戶的頁面。Atomic組件的優(yōu)勢不只是通過模塊化和可重用的組件來構建模塊化UI應用程序。這種范例迫使你思考組成每個組件的角色和API。3.4、Web組裝
Web程序集將語言多樣性帶入Web開發(fā)中,以彌補JavaScript創(chuàng)建的空白。它被定義為“基于堆棧的虛擬機的二進制指令格式。Wasm被設計為可移植目標,用于編譯高級語言(如C/C ++/Rust),從而可以在Web上為客戶端和服務器應用程序進行部署。”埃里克·埃利奧特在他的文章中優(yōu)雅地概述了該概念的好處:在wasm中實現(xiàn)對性能至關重要的內(nèi)容,并將其像標準JavaScript模塊一樣導入。一種新語言:WebAssembly代碼定義了以二進制格式表示的AST(抽象語法樹)。您可以編寫和調(diào)試文本格式,以便于閱讀。對瀏覽器的改進:瀏覽器將理解二進制格式,這意味著我們將能夠編譯二進制捆綁包,壓縮后的二進制包小于我們今天使用的文本JavaScript。較小的有效載荷意味著更快的傳遞。根據(jù)編譯時的優(yōu)化機會,WebAssembly的運行速度可能比JavaScript快!3.5、封裝樣式和Shadow Dom
組件的一個重要方面是封裝-能夠使標記結(jié)構,樣式和行為保持隱藏狀態(tài),并與頁面上的其他代碼分開,以使不同部分不會沖突,并且代碼可以保持整潔。Shadow DOM API是其中的關鍵部分,它提供了一種將隱藏的單獨DOM附加到元素的方法。Shadow DOM實際上已經(jīng)被瀏覽器使用了很長時間了。您可以將影子DOM視為“ DOM中的DOM”。它是自己的隔離DOM樹,具有自己的元素和樣式,與原始DOM完全隔離。它允許將隱藏的DOM樹附加到常規(guī)DOM樹中的元素上。該陰影DOM樹以影子根開頭,可以與普通DOM相同的方式附加到所需的任何元素上。這樣做的主要目的是,我們不需要為類使用名稱空間,因為不存在名稱沖突或樣式溢出的風險。這就是Web組件樣式進行真正封裝的解決方案。3.6、TypeScript接管前端
最近的每次交談都聽起來好像TS正在接管前端開發(fā)。據(jù)報道,有80%的開發(fā)人員承認他們想在下一個項目中使用或?qū)W習TypeScript。盡管有缺點,但TS代碼更易于理解,實現(xiàn)更快,產(chǎn)生的錯誤更少。想重構你的React應用程序并與TS一起使用嗎?去吧。想逐步開始嗎?使用Bit之類的工具逐步將你的應用程序中的組件重構為TS,并使用React-Typescript編譯器獨立于應用程序構建它們。TypeScript,它是有類型定義的 JavaScript 的超集,包括 ES5、ES5+ 和其他一些諸如反射、泛型、類型定義、命名空間等特征的集合,為了大規(guī)模 JavaScript 應用開發(fā)而生。復雜軟件需要用復雜的設計,面向?qū)ο缶褪且环N很好的設計方式,使用 TypeScript 的一大好處就是 TypeScript 提供了業(yè)界認可的類( ES5+ 也支持)、泛型、封裝、接口面向?qū)ο笤O計能力,以提升 JavaScript 的面向?qū)ο笤O計能力。市面上的框架也對 TypeScript 提供了非常好的支持。React 對.tsx 支持非常好,比如我在 Midway controller 里支持 tsx 寫法,這是非常大膽的,對于后面 react ssr 來說是一個極大便利;Vue 從 v2.5.0 之后對 ts 支持就非常好;Node.js Web 框架,尤其是 Egg.js 對 ts 支持非常好,當然還有更高級更專注的的 Midway 框架,Midway 基于 Egg 生態(tài),同時提供 IoC 等高級玩法;在使用 Webpack 編譯前端應用式,通過 TypeScript-loader 可以很輕松地將 TypeScript 引入到 Webpack 中。有了 TypeScript-loader,就可以一邊使用 TypeScript 編寫新代碼,一邊零碎地更新老代碼。畢竟 ts 是 js 超集,你有空就改,非強制,特別包容。3.7、從組件庫到動態(tài)集合
組件開發(fā)的出現(xiàn)催生出了一種工具的產(chǎn)生,它就是Bit,以及其托管平臺Bit.dev。使用Bit來連續(xù)隔離現(xiàn)有組件并將其導出到動態(tài)可重用的共享集合中,而無需努力構建麻煩且高度耦合的組件庫。使用Bit,你可以獨立隔離,版本控制,構建,測試和更新UI組件。它簡化了在現(xiàn)有應用程序中隔離組件,將其收集到遠程集合并在任何地方使用的過程。每個組件都可以在任何項目之外構建,測試和渲染。你可以更新單個組件(及其相關組件),而不是整個應用程序。在bit.dev平臺中(或在你自己的服務器上),可以為不同的團隊遠程托管和組織組件,以便每個團隊都可以控制自己的組件開發(fā)。每個團隊都可以共享和重用組件,但又保持其獨立性和控制力。該平臺還提供了共享組件的多合一生態(tài)系統(tǒng):它自動記錄UI組件的文檔,在交互式中渲染組件,甚至提供內(nèi)置注冊表以使用npm安裝組件。此外,你可以在任何存儲庫中導入組件并進行修改。在短期內(nèi),這以與Spotify/iTunes更改以前通過靜態(tài)CD音樂專輯共享音樂的過程類似的方式,徹底改變了共享和組成組件的過程。這是一個動態(tài)的模塊化解決方案,每個人都可以共享和使用組件。從長遠來看,Bit有助于微前端的開發(fā)。主要是因為它已經(jīng)可以讓你獨立版本,測試,構建和更新UI應用程序的各個部分。3.8、設計與開發(fā)的整合
隨著組件驅(qū)動設計系統(tǒng)的興起,使產(chǎn)品和團隊之間的UI一致,新工具應運而生,彌合了設計師和開發(fā)人員之間的鴻溝。但是,這不是簡單的任務。盡管代碼本身實際上是唯一的真理源(這是用戶真正得到的),但是大多數(shù)工具都試圖彌合設計者與設計者之間的鴻溝。在此類別中,您可以找到成幀器,F(xiàn)igma,Invision DSM等。在開發(fā)人員的末端,你可以看到Bit.dev之類的平臺如何托管下一代組件庫并幫助建立共享組件的采用范圍。該平臺為您的實際源代碼提供了呈現(xiàn)的可視化效果,以便設計人員可以與開發(fā)人員合作,并以可視化方式在源代碼本身上進行討論。要注意的另一個有前途的想法是設計令牌。將令牌放置在代碼中,設計人員可以通過它們直接與外部協(xié)作工具真正控制簡單的樣式方面(例如顏色)。與Bit.dev等平臺集成后,可以創(chuàng)建比以往更緊密的工作流程。3.9、跨端開發(fā)框架迅猛發(fā)展
從最初的React Native,到后來的Flutter,electron,跨端的解決方案受到了大量前端工程師的關注和學習。Flutter2的發(fā)布,其Web開發(fā)能力也過度到了穩(wěn)定版本,同時桌面端開發(fā)能力也進入了beta階段,進一步提高了代碼的復用性,同時它也拓展了很多IOS的功能,生態(tài)進一步壯大。近乎一套代碼便可以完成移動端、web端、桌面端應用的開發(fā),大大縮減開發(fā)人員學習其他平臺開發(fā)技術的成本,一線互聯(lián)網(wǎng)公司也在將其部分應用使用Flutter進行重構。electron作為一個基于Nodejsde桌面端跨端開發(fā)框架,深受大廠的喜愛,飛書、vscode、twitch等均是基于electron進行開發(fā)。跨平臺也讓 Electron 可同時開發(fā) Web 應用和桌面應用,無論是 UI,還是代碼,很多資源都可以共享,大幅減少了開發(fā)者的工作量。需求推動著跨端框架的發(fā)展,無論從成本還是效率考慮,跨端開發(fā)都將成為前端開發(fā)未來的發(fā)展方向之一,其生態(tài)也會迎來瘋狂擴張。3.10、低代碼平臺持續(xù)發(fā)展
隨著十四五規(guī)劃的推出,進一步推動了企業(yè)數(shù)字化轉(zhuǎn)型的步伐,眾多企業(yè)面臨數(shù)字化轉(zhuǎn)型。相較于培養(yǎng)一支開發(fā)團隊,多數(shù)企業(yè)更傾向于使用低代碼平臺,通過無編碼或低編碼的方式快速搭建自己的數(shù)字化系統(tǒng)。同時,低代碼平臺迎來了爆發(fā)式的增長,至今仍將保持50%的平穩(wěn)增速。平臺快速發(fā)展,覆蓋的業(yè)務場景也逐漸增多,中小企業(yè)95%以上的場景可通過低代碼平臺搭建,中大型企業(yè)的覆蓋率也能達到70%。低代碼平臺的迅猛發(fā)展,很多業(yè)務場景的開發(fā)工作逐漸被平臺替代,很多簡單的前端頁面的開發(fā)都會轉(zhuǎn)移到平臺中完成,初級前端工程師的生存重建逐漸被蠶食。同時低代碼平臺的發(fā)展也會對前端工程師提出了更高的要求。4、總結(jié)
前端開發(fā)趨勢一直都是熱度高且變化快。因此,對于前端開發(fā)者來說,想要跟上這些不斷變化的趨勢,需要耗費巨大的精力。至于2022年前端技術具體會發(fā)生哪些變化,讓我們拭目以待吧。本文分享自華為云社區(qū)《2022前端技術領域會有哪些新的變化》,作者:架構師李肯。
前端程序員是軟件開發(fā)團隊中的重要組成部分,隨著移動互聯(lián)網(wǎng)的發(fā)展,用戶對于前端頁面的使用體驗有越來越高的要求,這進一步提升了前端程序員的重要程度。從這個角度來看,轉(zhuǎn)行做前端程序員是個不錯的選擇。
雖然前端程序員的崗位比較重要,但是目前科技公司對于前端程序員的知識結(jié)構也有更高的要求,如果只會單純的做網(wǎng)頁的前端開發(fā),那么職場競爭力往往要弱一些。目前前端開發(fā)程序員應該具備以下知識結(jié)構:
第一:傳統(tǒng)Web前端知識。傳統(tǒng)Web前端知識包括Html、CSS和JavaScript,其中JavaScript是學習的重點和難點,應該重點掌握。隨著Nodejs的應用,JavaScript正逐漸從前端走向后端,所以JavaScript未來的發(fā)展空間還是比較大的。
第二:移動端開發(fā)知識。隨著移動互聯(lián)網(wǎng)的發(fā)展,移動端的前端開發(fā)也需要重點掌握,包括Html5、Android開發(fā)、iOS開發(fā)等。目前已經(jīng)有不少團隊把移動端開發(fā)并入到前端開發(fā)團隊,這就要求前端開發(fā)人員要具備更加豐富的知識結(jié)構以應對這種變化。
第三:后端開發(fā)知識。雖然前端開發(fā)并不會涉及到更多的后端開發(fā)內(nèi)容,但是掌握一定的后端開發(fā)知識還是有必要的,尤其在當前的前端開發(fā)后端化的大背景下。按照歷史經(jīng)驗來看,掌握一定的后端開發(fā)知識會在一定程度上提升前端開發(fā)的效率。通常來說,學習一下Java Web開發(fā)就是一個不錯的選擇。
隨著Web開發(fā)的不斷發(fā)展,未來前端開發(fā)的發(fā)展空間還是比較大的,從就業(yè)的角度來看,學習前端開發(fā)是個不錯的選擇。
我從事互聯(lián)網(wǎng)行業(yè)多年,目前也在帶計算機專業(yè)的研究生,主要的研究方向集中在大數(shù)據(jù)和人工智能領域,我會陸續(xù)在頭條寫一些關于互聯(lián)網(wǎng)技術方面的文章,感興趣的朋友可以關注我,相信一定會有所收獲。
如果有互聯(lián)網(wǎng)方面的問題,也可以咨詢我,謝謝!