You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
* Suggest `serve` for serving the `build` directory
* How to handle it with Node in prod (or other platforms)
* Pretty newline added
* Adjusted default port of static server
* Remove `open` command from output
* Removed constant assignment
* Better explanation for not using having to use a static server
* Cute newline added
* Style nits
Copy file name to clipboardexpand all lines: packages/react-scripts/template/README.md
+25-5
Original file line number
Diff line number
Diff line change
@@ -62,6 +62,8 @@ You can find the most recent version of this guide [here](https://github.com/fac
62
62
-[Developing Components in Isolation](#developing-components-in-isolation)
63
63
-[Making a Progressive Web App](#making-a-progressive-web-app)
64
64
-[Deployment](#deployment)
65
+
-[Static Server](#static-server)
66
+
-[Other Solutions](#other-solutions)
65
67
-[Serving Apps with Client-Side Routing](#serving-apps-with-client-side-routing)
66
68
-[Building for Relative Paths](#building-for-relative-paths)
67
69
-[Azure](#azure)
@@ -1210,14 +1212,30 @@ You can turn your React app into a [Progressive Web App](https://developers.goog
1210
1212
1211
1213
## Deployment
1212
1214
1213
-
`npm run build` creates a `build` directory with a production build of your app. Set up your favourite HTTP server so that a visitor to your site is served `index.html`, and requests to static paths like `/static/js/main.<hash>.js` are served with the contents of the `/static/js/main.<hash>.js` file. For example, Python contains a built-in HTTP server that can serve static files:
1215
+
`npm run build` creates a `build` directory with a production build of your app. Set up your favourite HTTP server so that a visitor to your site is served `index.html`, and requests to static paths like `/static/js/main.<hash>.js` are served with the contents of the `/static/js/main.<hash>.js` file.
1216
+
1217
+
### Static Server
1218
+
1219
+
For environments using [Node](https://nodejs.org/), the easiest way to handle this would be to install [serve](https://github.com/zeit/serve) and let it handle the rest:
1220
+
1221
+
```sh
1222
+
npm install -g serve
1223
+
serve -s build
1224
+
```
1225
+
1226
+
The last command shown above will serve your static site on the port **5000**. Like many of [serve](https://github.com/zeit/serve)’s internal settings, the port can be adjusted using the `-p` or `--port` flags.
1227
+
1228
+
Run this command to get a full list of the options available:
1214
1229
1215
1230
```sh
1216
-
cd build
1217
-
python -m SimpleHTTPServer 9000
1231
+
serve -h
1218
1232
```
1219
1233
1220
-
If you’re using [Node](https://nodejs.org/) and [Express](http://expressjs.com/) as a server, it might look like this:
1234
+
### Other Solutions
1235
+
1236
+
You don’t necessarily need a static server in order to run a Create React App project in production. It works just as fine integrated into an existing dynamic one.
1237
+
1238
+
Here’s a programmatic example using [Node](https://nodejs.org/) and [Express](http://expressjs.com/):
1221
1239
1222
1240
```javascript
1223
1241
constexpress=require('express');
@@ -1233,7 +1251,9 @@ app.get('/', function (req, res) {
1233
1251
app.listen(9000);
1234
1252
```
1235
1253
1236
-
Create React App is not opinionated about your choice of web server. Any static file server will do. The `build` folder with static assets is the only output produced by Create React App.
1254
+
The choice of your server software isn’t important either. Since Create React App is completely platform-agnostic, there’s no need to explicitly use Node.
1255
+
1256
+
The `build` folder with static assets is the only output produced by Create React App.
1237
1257
1238
1258
However this is not quite enough if you use client-side routing. Read the next section if you want to support URLs like `/todos/42` in your single-page app.
0 commit comments