If you need this template with tailwind there is a branch in this repository with this name (tailwind)
-
Create a development Docker container with the minimum Node.js version required for Nuxt, which is version 18 in alpine.
docker run -it --rm node:18-alpine sh
-
Wait for it to finish when you see this message. Install Nuxt in the environment
npx nuxi@latest init your_name
(select nuxi@3.11.1, yes).Choose your package manager (I use npm). -
We do not need a repository since we will only copy the files in another folder, and we will not need this development Docker container later.
-
Navigate to your folder.
-
MOST IMPORTANTLY, run
npm i
in this environment, and do not close the terminal, or you will lose everything (development environment only).
-
Open another terminal without closing the previous one, navigate to the location where you want to develop your project. Find the ID of the container created in the first terminal using docker ps
-
Copy the contents of the image to the desired location using
docker cp saved_id:your_folder_name .
DO NOT FORGET THE TRAILING PERIOD AT THE END -
Check that it has been created using
ls
and navigate to the folder usingcd your_folder_name
and open your IDE, I use vsc for this, so I usecode .
Step 3
- In the IDE (I use vsc), create .dockerignore and Dockerfile.
.dockerignore
# Node dependencies
node_modules
# Local env files
.env
.env.*
!.env.example
Dockerfile
FROM node:18-alpine
WORKDIR /docker-nuxt
COPY . .
EXPOSE 3000
CMD ["npm","run", "dev", "--", "--host"]
-
Create the Nuxt_DEV image using
docker build -t name_of_the_image_you_want .
This will read the Dockerfile and create an image based on it. If you are using Docker Desktop, you will see the image and its ID (the number below). You can also use docker ps and see it in the terminal. Copy and save the ID. -
Now you can create a container from this image with the volume direction in your project with:
docker run -d -p new_port_you_want:port_in_dockerfile -v ABSOLUTE_PATH_YOUR_WORK_APP:PATH_OF_YOUR_IMAGE --name NAME_TO_YOUR_CONTAINER_you_WANT name_or_ID_of_the_image
NOW you can open your port and see this (mine was 3001)
Change something in the app.vue to test, and you should see the changes immediately.
NOTE: You can start (or stop) your container quickly in your docker desktop (actions):
After that you can start your app folder as a repo if you need it.