Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/express-ts/create-npack-app
https://github.com/express-ts/create-npack-app
babel cli create-node-app create-npack-app node-js npx nvm server-side webpack zero-configuration
Last synced: 10 days ago
JSON representation
- Host: GitHub
- URL: https://github.com/express-ts/create-npack-app
- Owner: express-ts
- License: mit
- Created: 2020-07-19T14:50:57.000Z (over 4 years ago)
- Default Branch: dev
- Last Pushed: 2020-11-28T00:36:45.000Z (about 4 years ago)
- Last Synced: 2024-04-25T08:20:48.182Z (9 months ago)
- Topics: babel, cli, create-node-app, create-npack-app, node-js, npx, nvm, server-side, webpack, zero-configuration
- Language: JavaScript
- Homepage:
- Size: 11.4 MB
- Stars: 1
- Watchers: 2
- Forks: 0
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG-0.x.md
- Contributing: CONTRIBUTING.md
- License: LICENSE
- Code of conduct: CODE_OF_CONDUCT.md
- Codeowners: .github/CODEOWNERS
Awesome Lists containing this project
README
# Create Node.js App [![Build Status](https://dev.azure.com/express-ts/create-npack-app/_apis/build/status/facebook.create-npack-app?branchName=master)](https://dev.azure.com/express-ts/create-npack-app/_build/latest?definitionId=1&branchName=master) [![PRs Welcome](https://img.shields.io/badge/PRs-welcome-green.svg)](https://github.com/express-ts/create-npack-app/blob/master/CONTRIBUTING.md)
Create Server-side apps with no build configuration.
- [Creating an App](#creating-an-app) – How to create a new app.
- [User Guide](https://facebook.github.io/create-npack-app/) – How to develop apps bootstrapped with Create Npack App.Create Npack App works on macOS, Windows, and Linux.
If something doesn’t work, please [file an issue](https://github.com/facebook/create-react-app/issues/new).
If you have questions or need help, please ask in [GitHub Discussions](https://github.com/facebook/create-npack-app/discussions).## Quick Overview
```sh
npx create-npack-app my-app
cd my-app
npm start
```If you've previously installed `create-npack-app` globally via `npm install -g create-npack-app`, we recommend you uninstall the package using `npm uninstall -g create-npack-app` or `yarn global remove create-react-app` to ensure that npx always uses the latest version.
_([npx](https://medium.com/@maybekatz/introducing-npx-an-npm-package-runner-55f7d4bd282b) comes with npm 5.2+ and higher, see [instructions for older npm versions](https://gist.github.com/gaearon/4064d3c23a77c74a3614c498a8bb1c5f))_
Then open [http://localhost:3000/](http://localhost:3000/) to see your app.
When you’re ready to deploy to production, create a minified bundle with `npm run build`.
### Get Started Immediately
You **don’t** need to install or configure tools like webpack or Babel.
They are preconfigured and hidden so that you can focus on the code.Create a project, and you’re good to go.
## Creating an App
**You’ll need to have Node 8.16.0 or Node 10.16.0 or later version on your local development machine** (but it’s not required on the server). You can use [nvm](https://github.com/creationix/nvm#installation) (macOS/Linux) or [nvm-windows](https://github.com/coreybutler/nvm-windows#node-version-manager-nvm-for-windows) to switch Node versions between different projects.
To create a new app, you may choose one of the following methods:
### npx
```sh
npx create-npack-app my-app
```_([npx](https://medium.com/@maybekatz/introducing-npx-an-npm-package-runner-55f7d4bd282b) is a package runner tool that comes with npm 5.2+ and higher, see [instructions for older npm versions](https://gist.github.com/gaearon/4064d3c23a77c74a3614c498a8bb1c5f))_
### npm
```sh
npm init react-app my-app
```_`npm init ` is available in npm 6+_
### Yarn
```sh
yarn create react-app my-app
```_[`yarn create `](https://yarnpkg.com/lang/en/docs/cli/create/) is available in Yarn 0.25+_
It will create a directory called `my-app` inside the current folder.
Inside that directory, it will generate the initial project structure and install the transitive dependencies:```
my-app
├── README.md
├── node_modules
├── package.json
├── .gitignore
├── public
│ ├── favicon.ico
│ ├── index.html
│ └── manifest.json
└── src
├── App.css
├── App.js
├── App.test.js
├── index.css
├── index.js
├── logo.svg
└── serviceWorker.js
└── setupTests.js
```No configuration or complicated folder structures, only the files you need to build your app.
Once the installation is done, you can open your project folder:```sh
cd my-app
```Inside the newly created project, you can run some built-in commands:
### `npm start` or `yarn start`
Runs the app in development mode.
Open [http://localhost:3000](http://localhost:3000) to view it in the browser.The page will automatically reload if you make changes to the code.
You will see the build errors and lint warnings in the console.
### `npm test` or `yarn test`
Runs the test watcher in an interactive mode.
By default, runs tests related to files changed since the last commit.[Read more about testing.](https://facebook.github.io/create-npack-app/docs/running-tests)
### `npm run build` or `yarn build`
Builds the app for production to the `build` folder.
It correctly bundles Express in production mode and optimizes the build for the best performance.Your app is ready to be deployed.
## User Guide
You can find detailed instructions on using Create Npack App and many tips in [its documentation](https://facebook.github.io/create-npack-app/).
## How to Update to New Versions?
Please refer to the [User Guide](https://facebook.github.io/create-npack-app/docs/updating-to-new-releases) for this and other information.
## Philosophy
- **One Dependency:** There is only one build dependency. It uses webpack, Babel, ESLint, and other amazing projects, but provides a cohesive curated experience on top of them.
- **No Configuration Required:** You don't need to configure anything. A reasonably good configuration of both development and production builds is handled for you so you can focus on writing code.
- **No Lock-In:** You can “eject” to a custom setup at any time. Run a single command, and all the configuration and build dependencies will be moved directly into your project, so you can pick up right where you left off.
## What’s Included?
Your environment will have everything you need to build a modern single-page @express app:
- Node.js, Express, ES6, TypeScript and Flow syntax support.
- Language extras beyond ES6 like the object spread operator.
- A fast interactive unit test runner with built-in support for coverage reporting.
- A live development server that warns about common mistakes.
- A build script to bundle TS, JS, and images for production, with hashes and sourcemaps.
- Hassle-free updates for the above tools with a single dependency.Check out [this guide](https://github.com/nitishdayal/cra_closer_look) for an overview of how these tools fit together.
The tradeoff is that **these tools are preconfigured to work in a specific way**. If your project needs more customization, you can ["eject"](https://facebook.github.io/create-npack-app/docs/available-scripts#npm-run-eject) and customize it, but then you will need to maintain this configuration.
## Popular Alternatives
Create Npack App is a great fit for:
- **Learning React** in a comfortable and feature-rich development environment.
- **Starting new single-page React applications.**
- **Creating examples** with React for your libraries and components.Here are a few common cases where you might want to try something else:
- If you want to **try React** without hundreds of transitive build tool dependencies, consider [using a single HTML file or an online sandbox instead](https://reactjs.org/docs/try-react.html).
- If you need to **integrate React code with a server-side template framework** like Rails, Django or Symfony, or if you’re **not building a single-page app**, consider using [nwb](https://github.com/insin/nwb), or [Neutrino](https://neutrino.js.org/) which are more flexible. For Rails specifically, you can use [Rails Webpacker](https://github.com/rails/webpacker). For Symfony, try [Symfony's webpack Encore](https://symfony.com/doc/current/frontend/encore/reactjs.html).
- If you need to **publish a React component**, [nwb](https://github.com/insin/nwb) can [also do this](https://github.com/insin/nwb#react-components-and-libraries), as well as [Neutrino's react-components preset](https://neutrino.js.org/packages/react-components/).
- If you want to do **server rendering** with React and Node.js, check out [Next.js](https://github.com/zeit/next.js/) or [Razzle](https://github.com/jaredpalmer/razzle). Create Npack App is agnostic of the backend, and only produces static HTML/JS/CSS bundles.
- If your website is **mostly static** (for example, a portfolio or a blog), consider using [Gatsby](https://www.gatsbyjs.org/) instead. Unlike Create Npack App, it pre-renders the website into HTML at the build time.
- Finally, if you need **more customization**, check out [Neutrino](https://neutrino.js.org/) and its [React preset](https://neutrino.js.org/packages/react/).
All of the above tools can work with little to no configuration.
If you prefer configuring the build yourself, [follow this guide](https://reactjs.org/docs/add-react-to-an-existing-app.html).
## React Native
Looking for something similar, but for React Native?
Check out [Expo CLI](https://github.com/expo/expo-cli).## Contributing
We'd love to have your helping hand on `create-npack-app`! See [CONTRIBUTING.md](CONTRIBUTING.md) for more information on what we're looking for and how to get started.
## Credits
This project exists thanks to all the people who [contribute](CONTRIBUTING.md).
Thanks to [Netlify](https://www.netlify.com/) for hosting our documentation.
## Acknowledgements
We are grateful to the authors of existing related projects for their ideas and collaboration:
- [@eanplatter](https://github.com/eanplatter)
- [@insin](https://github.com/insin)
- [@mxstbr](https://github.com/mxstbr)## License
Create Npack App is open source software [licensed as MIT](https://github.com/express-ts/create-npack-app/blob/master/LICENSE).