In this brief tutorial, I'll guide you through the process of deploying your project on GitHub Pages. I'm assuming that your project is complete and ready for deployment.
Now, let's follow these instructions step by step:
1. Creating your Repository
To start, create a new public repository on GitHub. If you already have one, feel free to skip this step.
2. Connect your repo with your app
You can use commands below for this:
git remote add origin https://github.com/{username}/{your_repo_name}.git
then create a branch and name it to main
by this:
git branch -M main
After this step, you have to push your code on GitHub. Maybe need this:
git push --set-upstream origin main
3. Create your Action And Deploy it
In this step you should go to the Settings
tab and then Pages
section.
Next, in the Branch
section, select the main
branch and click the save button next to it.
After that, the page reload and in Build and deployment
section you should open the menu in the Source
section and choose GitHub Actions
option.
Now you see that GitHub make a URL for your repo that you can see the content in there, but we still have some work to do.
You should now see a display similar to this. In this section, you can set up your deployment process using GitHub Action workflows. As shown in the image, GitHub typically identifies your repository workflow automatically. If it doesn't, don't worry, there's an easier way to manage it.
Now you should click on the Configure
button as you see above. Then copy the below content and paste it in the editor you can see in the next page.
# https://github.com/actions/deploy-pages#usage
name: Deploy to GitHub Pages
on:
workflow_dispatch:
push:
branches:
- main
jobs:
build:
runs-on: ubuntu-latest
steps:
- uses: actions/checkout@v4
- run: corepack enable
- uses: actions/setup-node@v4
with:
node-version: "20"
# Pick your own package manager and build script
- run: npm install
- run: npx nuxt build --preset github_pages
- name: Upload artifact
uses: actions/upload-pages-artifact@v3
with:
path: ./.output/public
# Deployment job
deploy:
# Add a dependency to the build job
needs: build
# Grant GITHUB_TOKEN the permissions required to make a Pages deployment
permissions:
pages: write # to deploy to Pages
id-token: write # to verify the deployment originates from an appropriate source
# Deploy to the github_pages environment
environment:
name: github_pages
url: ${{ steps.deployment.outputs.page_url }}
# Specify runner + deployment step
runs-on: ubuntu-latest
steps:
- name: Deploy to GitHub Pages
id: deployment
uses: actions/deploy-pages@v4
Now almost done, you should click on the Commit changes...
button and commit your changes.
In the pop-up windows, you have the option to include additional content for your commit. If you choose not to, there's no negative consequence.
Once you've committed your changes, navigate to the Actions
tab. There, you'll see an indication that your workflow has begun its job. You will need to wait for it to complete:
After a few minutes, the yellow flag next to your workflow name will change to green, indicating everything has been successfully completed.
Then, if you click on the name of your workflow, you can see this:
If you click the link generated by GitHub, you'll be able to see the results. To me, the outcome is as follows:
Congratulations, you did it👏.
4. Updating your project
To make changes to your project, such as adding a section to a page, simply commit your modifications and push them to GitHub, it manages other stuff with your workflow that we add it earlier.
- After pushing your changes and go to your GitHub page, you see something like this:
After a couple of minutes of waiting, the yellow sign turns green, and then your page has been successfully updated!. For me turn in to this:
Conclusions
You have now learned how to automatically deploy your Nuxt.js app using the GitHub Pages workflow system, and you understand how to update it with ease.
I am thrilled to explore my website hosseinmirhosseini76.github.io😊👋
Top comments (0)