This is an example code, simulating how to run Vite on traditional PHP sites.
A bare-minimum setup to serve as example to adapt to other scenarios (WordPress, Laravel, etc).
For everything else beyond the PHP side please refer to the Vite documentation, which is great.
- comes with nginx and preinstalled npm in the correct version
- add entry in hosts-file:
127.0.0.1 vite-php-setup.test
docker-compose up
docker exec -w /app/vite vite-php-setup.php npm run dev
- open
http://vite-php-setup.test:8114/
- voilà!
- Handle the cleanest way possible;
- Works gracefully!
A characteristic of this setup is that you'll run your project from your own local server, for exemple http://vite-php-setup.test. Vite will be running at http://localhost:5133 where our script and styles will be served from, but accesing http://localhost:5133 directly will be empty, which is fine.
Of course, HMR and styles will work just fine! And fast!
- Mininum Node.js version >=14.18+
- The "public" folder is the web server's public root, "public/index.php" is the front controller or bootstrap file;
- The "vite" folder is outside of public root intentionaly, where it would actually be within a PHP app;
- For the sake of this example, we are not setting up a SPA, instead we have multiple Vue components sprinkled throughout your page, simulating the mix of regular HTML with interactive elements (using in-DOM HTML as the template);
- This examples uses Vue, for React refer to this info;
A limitation is Vite's port during development, PHP helpers must match the one that was created during "npm run dev" (default 5173). For example, if the port 5173 is in use, Vite will try the next one (5174 and so on), so our helper PHP wouldn't know about that.
The solution is to stricly specify which port to use, and match the PHP side to the same port. Check vite.config.js for example.
Image urls within CSS works fine BUT you need to create a symlink on dev server to map to your assets folder. This is an expected limitation as noted on Vite docs
The solution is here, adjust the paths and run in terminal:
ln -s {path_to_project_source}/src/assets {path_to_public_html}/assets
Note: this happens because our Vite code is outside the server public access, if it where, we could use server.origin config.
You may find the need to handle multiple entries, for example, one js/css for the backend and another js/css for frontend. For that, it depends directly on how you want to organize your code.
So you can have:
- A single Vite multi-page setup.
- A shared Vite setup, but outputing different entries in separated build steps, example here.
To get this running on Docker quickly, check out this fork. Thanks @mrothauer