Modern.js現(xiàn)代 Web 工程體系
Modern.js 是一個(gè)從頭開始設(shè)計(jì)的元框架套件,用于專注于前端的現(xiàn)代 Web 開發(fā)。
Modern.js 將以往海量的前端工程模板,收斂成三大工程類型:應(yīng)用、模塊、Monorepo,每種類型都只需要同一套模板、同一套工程方案。其中“應(yīng)用”工程方案又被稱作“MWA”(現(xiàn)代 Web 應(yīng)用),基于一套客戶端為中心、前后端一體化的應(yīng)用開發(fā)框架,實(shí)現(xiàn)了強(qiáng)大的“Universal App”模式。即一套應(yīng)用源代碼,能同時(shí)在客戶端、服務(wù)器端、編譯時(shí)里運(yùn)行,能以靜態(tài) Web(SPA、MPA、SSG)、動(dòng)態(tài) Web(SSR、SPR)、微前端、桌面應(yīng)用、小程序等不同模式運(yùn)行,同時(shí)支持低門檻、全功能、一體化的 BFF (針對(duì)特定界面的服務(wù)器端 API)開發(fā)。
“MWA”是 Serverless 優(yōu)先的,內(nèi)置產(chǎn)品級(jí) Web Server。它能在開發(fā)、調(diào)試、部署、運(yùn)行等所有環(huán)節(jié)做到盡可能“無服務(wù)器化”,同時(shí)確?!伴_發(fā)者體驗(yàn)”和“用戶體驗(yàn)”,讓更多“前端開發(fā)者”成為獨(dú)立、全面的“應(yīng)用開發(fā)者”和“產(chǎn)品開發(fā)者”。Modern.js 也原生支持微前端、Electron 桌面應(yīng)用、Monorepo 等研發(fā)場(chǎng)景。
Modern.js 從最初就設(shè)計(jì)為 ESM 優(yōu)先,在“編譯時(shí)”環(huán)節(jié)能更好的支持 Unbundled 開發(fā)、非 JS 語言的編譯器等第三代 JS 工具的發(fā)展。在“運(yùn)行時(shí)”環(huán)節(jié),Modern.js 提供開箱即用的應(yīng)用架構(gòu),提供在“應(yīng)用”工程方案、“模塊”工程方案里都能無縫使用的 Runtime API 標(biāo)準(zhǔn)庫。在“編寫時(shí)”環(huán)節(jié),Modern.js 鼓勵(lì)盡可能讓機(jī)器來生成源碼的智能編程。
特性:
- 客戶端為中心的 Web 框架
- JS 為中心、FP 優(yōu)先的 GUI 軟件研發(fā)技術(shù)棧
- 從“前后端分離”到“前后端一體化”
- Severless 優(yōu)先
- 對(duì) Web 應(yīng)用開發(fā)的充分抽象
- DX 和 UX 同時(shí)最大化
- 智能化
- 平臺(tái)化
- 低碼化
應(yīng)用架構(gòu)
Runtime API 標(biāo)準(zhǔn)庫
