Inspire creativity in modern web development.
English | 简体中文
The Modern.js framework is a progressive web framework based on React. At ByteDance, we use Modern.js to build upper-level frameworks that have supported the development of thousands of web applications.
When developing React applications, developers usually need to design implementation plans for certain features or use other libraries and frameworks to solve these problems. Modern.js supports all configurations and tools needed by React applications, and has built-in additional features and optimizations. Developers can use React to build the UI of the application, and then gradually adopt the features of Modern.js to solve common application requirements, such as routing, data acquisition, and state management.
See Quick Start.
The following solutions and libraries are available within the Modern.js ecosystem:
- 🦀 Rspack: A fast Rust-based web bundler.
- 🐬 Rsbuild: An Rspack-based build tool for the web, rebranded from Modern.js Builder.
- 🐹 Rspress: A fast Rspack-based static site generator.
- 🦄 Rslib: An Rspack-based library development tool.
- 🐟 Garfish: A powerful micro front-end framework.
- 🦆 Reduck: An redux-based state management library.
- 🐴 SWC Plugins: Built-in SWC plugins for Modern.js.
We use Modern.js Benchmark to observe the trend of key metrics, such as bundle size, compile speed and install size.
Please refer to the Modern.js Roadmap. We will update the Roadmap content regularly. Please stay tuned.
Modern.js provides a collection of ready-to-use examples that you can find and use in the modern-js-examples repository.
New contributors welcome!
Please read the Contributing Guide.
This repo has adopted the Bytedance Open Source Code of Conduct. Please check Code of Conduct for more details.
Thanks to the following friends for their contributions to Modern.js:
Some implementations of Modern.js are modified from existing projects, such as create-react-app, remix, jest and bundle-require. Thanks for them.
@modern-js/bundle-require
: is modified from bundle-require.@modern-js/plugin
: the hooks API is referenced from farrow-pipeline.@modern-js/plugin-testing
: the jest runner is referenced from jest-cli.@modern-js/plugin-data-loader
: some code is referenced from remix.@modern-js/babel-plugin-module-resolver
: is modified from babel-plugin-module-resolver.
Modern.js is MIT licensed.
Third party licenses are listed in THIRD-PARTY-LICENSE.