2019年的大前端領(lǐng)域雖然并沒有出現(xiàn)什么顛覆性技術(shù),但是Flutter、WebAssembly、Serverless的火爆發(fā)展還是超乎我們預期,也讓我們進一步看到大前端的融合趨勢。2020年下半年,大前端領(lǐng)域又有哪些你不能錯過的頂級技術(shù)趨勢呢?
創(chuàng)新互聯(lián)公司網(wǎng)站設(shè)計,為客戶量身定制各類網(wǎng)站建設(shè)業(yè)務(wù),包括企業(yè)型、電子商務(wù)型、響應式網(wǎng)站、行業(yè)門戶型等各類網(wǎng)站,實戰(zhàn)經(jīng)驗豐富,成功案例眾多。以客戶利益為出發(fā)點,創(chuàng)新互聯(lián)公司網(wǎng)站制作為客戶規(guī)劃、按需網(wǎng)站制作符合企業(yè)需求、帶有營銷價值的網(wǎng)絡(luò)建站方案認真對待每一個客戶,我們不用口頭的語言來吹擂我們的優(yōu)秀,千余家的成功案例見證著我們的成長。1、Web組件化
基本上這就是未來。為什么?因為這些純Web組件與框架無關(guān),并且可以在沒有框架或沒有任何框架拼寫標準化的情況下工作。因為它們沒有JS疲勞,并且得到了現(xiàn)代瀏覽器的支持。因為它們的文件大小和消耗將是最佳的,并且VDOM渲染令人贊嘆。
這些組件提供了Custom Element,這是一個Javascript API,可讓你定義新html標簽,HTML模板以指定布局,當然還有Shadow DOM,它本質(zhì)上是特定于組件的。在這個領(lǐng)域中知名的工具是Lit-html(和Lit-element),StencilJS,SvelteJS,當然還有Bit,它們是可重用的模塊化組件,可以在任何地方直接共享,使用和開發(fā)。考慮組件開發(fā)時代的未來,以及模塊化,可重用性,封裝和標準化的原理,Web組件就是答案。
2、微前端
盡管前端開發(fā)享有組件的模塊化優(yōu)勢,但與后端微服務(wù)相比,它在很大程度上仍是單一的。微前端帶來了前端體系結(jié)構(gòu)拆分為不同前端的功能,供從事應用程序開發(fā)不同部分的不同團隊使用。每個團隊都可以在其微前端的端到端生命周期中獲得自治權(quán),可以獨立地開發(fā),版本控制,測試,構(gòu)建,渲染,更新和部署(例如使用Bit等工具)。但是,當今的生態(tài)系統(tǒng)仍然存在某些缺點。
通常,人們會擔心諸如獨立的前端部署,捆綁,環(huán)境差異等問題。Bit已經(jīng)使您能夠隔離,版本化,構(gòu)建,測試和更新各個前端/組件。目前,這主要在使用多個應用程序時非常有用(盡管它已經(jīng)普遍用于通過組件逐步重構(gòu)現(xiàn)有應用程序的一部分)。當Bit將在2020年推出部署功能時,獨立團隊將有權(quán)開發(fā),編寫,版本化,部署和更新獨立前端。
你可以將UI應用程序組合在一起,并讓團隊使用獨立的連續(xù)部署和增量升級來創(chuàng)建簡單的解耦代碼庫。這些前端的組合最終幫助你創(chuàng)建應用程序。這就是使用Bit編寫的應用的好處。
3、微設(shè)計
布拉德·弗羅斯特(Brad Frost)提出的理論將Web應用程序的構(gòu)成與原子,分子,有機體等的自然構(gòu)成進行了比較,最后以具體的Web頁面作為結(jié)尾。原子由分子組成(例如,文本輸入+按鈕+標簽原子=搜索分子)。分子組成生物體。有機體位于布局模板中,該模板可以具體化為交付給用戶的頁面。
這是30秒的詳細說明,并附有視覺示例。它包括我用偉大的藝術(shù)才華制作的非常令人印象深刻的圖紙,您可以將其復制粘貼到您的辦公室板上。Atomic組件的優(yōu)勢不只是通過模塊化和可重用的組件來構(gòu)建模塊化UI應用程序。這種范例迫使你思考組成每個組件的角色和API。
4、Web組裝
Web程序集將語言多樣性帶入Web開發(fā)中,以彌補JavaScript創(chuàng)建的空白。它被定義為“基于堆棧的虛擬機的二進制指令格式。Wasm被設(shè)計為可移植目標,用于編譯高級語言(如C/C ++/Rust),從而可以在Web上為客戶端和服務(wù)器應用程序進行部署?!?/p>
埃里克·埃利奧特在他的文章中優(yōu)雅地概述了該概念的好處:在wasm中實現(xiàn)對性能至關(guān)重要的內(nèi)容,并將其像標準JavaScript模塊一樣導入。一種新語言:WebAssembly代碼定義了以二進制格式表示的AST(抽象語法樹)。您可以編寫和調(diào)試文本格式,以便于閱讀。對瀏覽器的改進:瀏覽器將理解二進制格式,這意味著我們將能夠編譯二進制捆綁包,壓縮后的二進制包小于我們今天使用的文本JavaScript。較小的有效載荷意味著更快的傳遞。根據(jù)編譯時的優(yōu)化機會,WebAssembly的運行速度可能比JavaScript快!
5、封裝樣式和Shadow Dom
組件的一個重要方面是封裝-能夠使標記結(jié)構(gòu),樣式和行為保持隱藏狀態(tài),并與頁面上的其他代碼分開,以使不同部分不會沖突,并且代碼可以保持整潔。Shadow DOM API是其中的關(guān)鍵部分,它提供了一種將隱藏的單獨DOM附加到元素的方法。Shadow DOM實際上已經(jīng)被瀏覽器使用了很長時間了。您可以將影子DOM視為“ DOM中的DOM”。它是自己的隔離DOM樹,具有自己的元素和樣式,與原始DOM完全隔離。
它允許將隱藏的DOM樹附加到常規(guī)DOM樹中的元素上。該陰影DOM樹以影子根開頭,可以與普通DOM相同的方式附加到所需的任何元素上。這樣做的主要目的是,我們不需要為類使用名稱空間,因為不存在名稱沖突或樣式溢出的風險。這就是Web組件樣式進行真正封裝的解決方案。
6、TypeScript接管前端
最近的每次交談都聽起來好像TS正在接管前端開發(fā)。據(jù)報道,有80%的開發(fā)人員承認他們想在下一個項目中使用或?qū)W習TypeScript。盡管有缺點,但TS代碼更易于理解,實現(xiàn)更快,產(chǎn)生的錯誤更少。想重構(gòu)你的React應用程序并與TS一起使用嗎?去吧。想逐步開始嗎?使用Bit之類的工具逐步將你的應用程序中的組件重構(gòu)為TS,并使用React-Typescript編譯器獨立于應用程序構(gòu)建它們。
7、從組件庫到動態(tài)集合
組件開發(fā)的出現(xiàn)催生出了一種工具的產(chǎn)生,它就是Bit,以及其托管平臺Bit.dev。使用Bit來連續(xù)隔離現(xiàn)有組件并將其導出到動態(tài)可重用的共享集合中,而無需努力構(gòu)建麻煩且高度耦合的組件庫。使用Bit,你可以獨立隔離,版本控制,構(gòu)建,測試和更新UI組件。它簡化了在現(xiàn)有應用程序中隔離組件,將其收集到遠程集合并在任何地方使用的過程。
每個組件都可以在任何項目之外構(gòu)建,測試和渲染。你可以更新單個組件(及其相關(guān)組件),而不是整個應用程序。在bit.dev平臺中(或在你自己的服務(wù)器上),可以為不同的團隊遠程托管和組織組件,以便每個團隊都可以控制自己的組件開發(fā)。每個團隊都可以共享和重用組件,但又保持其獨立性和控制力。
該平臺還提供了共享組件的多合一生態(tài)系統(tǒng):它自動記錄UI組件的文檔,在交互式中渲染組件,甚至提供內(nèi)置注冊表以使用npm安裝組件。此外,你可以在任何存儲庫中導入組件并進行修改。在短期內(nèi),這以與Spotify/iTunes更改以前通過靜態(tài)CD音樂專輯共享音樂的過程類似的方式,徹底改變了共享和組成組件的過程。這是一個動態(tài)的模塊化解決方案,每個人都可以共享和使用組件。
為什么說,從長遠來看,Bit有助于微前端的開發(fā)。主要是因為它已經(jīng)可以讓你獨立版本,測試,構(gòu)建和更新UI應用程序的各個部分。在2020年,它將引入獨立的部署,最終將允許不同的團隊,端到端的擁有應用程序的各個部分:保持分離和簡單的代碼庫,讓團隊謹慎,連續(xù)地構(gòu)建和部署增量UI升級,以及共同組成前端。
8、JAMStack
JAM是JavaScript、API和Markup的簡稱,前面第一個字母縮寫,而JAMstack是JavaScript、API和Markup構(gòu)建的技術(shù)堆棧,是一種基于客戶端JavaScript,可重用API和預構(gòu)建Markup的現(xiàn)代Web開發(fā)架構(gòu)。
9、設(shè)計與開發(fā)的整合
隨著組件驅(qū)動設(shè)計系統(tǒng)的興起,使產(chǎn)品和團隊之間的UI一致,新工具應運而生,彌合了設(shè)計師和開發(fā)人員之間的鴻溝。但是,這不是簡單的任務(wù)。盡管代碼本身實際上是唯一的真理源(這是用戶真正得到的),但是大多數(shù)工具都試圖彌合設(shè)計者與設(shè)計者之間的鴻溝。在此類別中,您可以找到成幀器,F(xiàn)igma,Invision DSM等。在開發(fā)人員的末端,你可以看到Bit.dev之類的平臺如何托管下一代組件庫并幫助建立共享組件的采用范圍。
該平臺為您的實際源代碼提供了呈現(xiàn)的可視化效果,以便設(shè)計人員可以與開發(fā)人員合作,并以可視化方式在源代碼本身上進行討論。要注意的另一個有前途的想法是設(shè)計令牌。將令牌放置在代碼中,設(shè)計人員可以通過它們直接與外部協(xié)作工具真正控制簡單的樣式方面(例如顏色)。與Bit.dev等平臺集成后,可以創(chuàng)建比以往更緊密的工作流程。
如果你想要拿到高薪,最可靠的方式就是靠自己的努力,夢想如果只想就會成為夢。作為IT教育全產(chǎn)業(yè)鏈人才服務(wù)平臺,千鋒教育長沙校區(qū)一直專注于IT人才服務(wù),有效指引了一批批學員的前行道路,讓他們少走了很多彎路,其中不乏一部分人實現(xiàn)了“彎道超車”,提前實現(xiàn)了職場晉升。感興趣的同學可以直接來岳麓區(qū)麓谷企業(yè)廣場A2棟3單元3樓上門參觀試聽咨詢。