This question actually follows directly from my answer on a previous question.
I added a \"homepage\"
to my package.json
because it is a Re
Docs for create-react-app
explains how to serve same build from different relative paths.
If you put homepage as
"homepage": ".",
assets will be served relative to index.html
. You will then be able to move your app from http://mywebsite.com
to http://mywebsite.com/relativepath
or even http://mywebsite.com/relative/path
without having to rebuild it.
For development purposes, serving using yarn start
or npm start
is good enough. App will be available in localhost
You can use PUBLIC_URL
environment variable to override the homepage for a specific build.
Even better have it set in your package.json, for instance:
{
// ...
"scripts": {
"build": "react-scripts build",
"build-localhost": "PUBLIC_URL=/ react-scripts build"
// ...
}
// ...
}
You can override the homepage setting using you dev shell environment:
$ export PUBLIC_URL=http://localhost:3000/
$ yarn start
or if you prefer, remove your homepage setting and configure your env before building for production:
$ export PUBLIC_URL=http://example.com/subdir
$ yarn build
For instance, problem can be because the 'index.html' file pointed to "/static/js/...js" and that will work if we release the application in the root folder, but if you have various static developments in the same machine using the same Apache Server you have a problem.
Configure Package.json with:
"homepage": "."
That will make use of relative paths instead of using absolute paths in the current folder. i.e. "./static/js/...js" Most common mistake while doing this change is inserting "./" and not "."
Further if you are not using react-router i.e. no client routing, you should be safe to go without this hack..