Creating an online portfolio is a fantastic way to showcase your work, skills, and personal brand.
Fortunately, you don’t need to be a web developer to get started, neither you need to spend money to host the server for your website.
GitHub Pages is a free and user-friendly platform that allows you to host your portfolio website directly from a GitHub repository.
Sounds exciting? In this tutorial, we’ll explore what GitHub Pages is, walk through creating a simple website and guide you on how to host it with your custom domain.
What are GitHub Pages?
GitHub Pages is a static site hosting service that takes files from a GitHub repository and serves them as a website. It’s designed primarily for hosting personal, project, or organizational websites.
You can use HTML, CSS, and JavaScript to create your site. GitHub Pages supports custom domains, making it a flexible option for anyone looking to establish an online presence.
Key features of GitHub Pages
- Free Hosting: Host your website without incurring costs.
- Version Control: Leverage Git’s version control features for your files.
- Custom Domains: Easily set up your own domain name.
- Jekyll Support: Utilize Jekyll, a static site generator, for more advanced setups.
Use a pre-designed template for your portfolio website
Okay, don’t judge me, I’m using a pre-built theme for this tutorial. But hey, it’s only because these themes are awesome and save a ton of time!
Of course, you can absolutely flex your creative muscles and design a jaw-dropping website from scratch if you want.
GitHub Pages works seamlessly with Jekyll, which offers an array of gorgeous themes to choose from.
Browse the Jekyll Themes directory
data:image/s3,"s3://crabby-images/3bde9/3bde99f01a969f91ce6c25542d991e1af6a444ce" alt="free jekyll themes directory"
And pick one that fits your taste:
data:image/s3,"s3://crabby-images/2e4ca/2e4caa0c8396372f80b5923c5d07b90adabda0fc" alt="Im using Freelancer theme template"
Fork or download the theme’s repository:
data:image/s3,"s3://crabby-images/65e8a/65e8a68db512c613a4e93cde50aeccc6a1dc0e7a" alt="downloading the jelyll theme from github in zip format"
yourname.github.io
or you can download it as a zip file and edit it locallyAnd start tweaking it to add your personality:
data:image/s3,"s3://crabby-images/28c6e/28c6eec6d7a347bd30c17f07ae5c21942e8acd4a" alt="editing the template and adding own details"
📋
You can edit even more details but that’s out of scope for this tutorial. I am more interested in showing the process of hosting websites with GitHub Pages rather than showing how to edit a theme.
Set up a GitHub repository
Create a GitHub Account: If you don’t have one, sign up at GitHub.
Create a new repository. Click on the “+” icon in the top-right corner and select “New repository.”
data:image/s3,"s3://crabby-images/298ef/298ef054a8707685b9ddf4d6474b6f8b1ad00c4d" alt="buttons to create a new repository"
Name your repository e.g., yourusername.github.io
and set it to public and click “Create repository.”
data:image/s3,"s3://crabby-images/91087/91087e185f5f4a6a56d50038899ffcf676e70bbf" alt="creating a new repo for github pages"
Upload your website files
Go to your new repository and click on “Add file” > “Upload files.”
data:image/s3,"s3://crabby-images/48300/48300055636fc377daae0a76dbebdeafca4bc3b7" alt="add files menu"
Drag and drop your HTML files (and any additional files like CSS or images) that you downloaded with the theme and commit your changes.
💡
If you are familiar with Git and GitHub, you can push the new files using git commands or VS Code. I am keeping things simpler by showing the web based upload.
data:image/s3,"s3://crabby-images/bae9c/bae9ca390aaa4df476ecc7eb48ed2af00221310d" alt="adding files via upload and commiting the changes"
Enable GitHub Pages
In your repository, go to “Settings.” and Scroll down to the “Pages” section. Under “Source,” select the branch (main/ master) and click “Save.”
After a few moments, your website will be live at https://yourusername.github.io
.
data:image/s3,"s3://crabby-images/da923/da9232f4f94ab1983c6d368b2aad581c7dac8372" alt="enabling github pages from the settings"
Set up a custom domain
If you have a custom domain, you can link it to your GitHub Pages site:
In your repository settings, under “Pages,” add your personal domain in the “Custom domain” section and save.
data:image/s3,"s3://crabby-images/83ed1/83ed16dfb2c077de644c69091f6f9258527e0524" alt="adding custom domain"
Add a CNAME record pointing to yourusername.github.io
data:image/s3,"s3://crabby-images/1826c/1826c9e129c12cb567f385743bd50cdb8b92f13b" alt="changing dns settings and adding a cname record"
If you are using an apex domain (like example.com
), add an A record pointing to GitHub’s IP addresses:
185.199.108.153
185.199.109.153
185.199.110.153
185.199.111.153
Verify your custom domain
After DNS propagation (which can take up to 48 hours), your custom domain should direct to your GitHub Pages site.
data:image/s3,"s3://crabby-images/ca3bc/ca3bccd13a56032688e67f562136f9a4448984cc" alt="our portfolio website is now live on our personal domain"
Conclusion
Hosting your portfolio website on GitHub Pages is a straightforward process that empowers you to showcase your skills and projects online.
With just a few steps, you can create and host a professional-looking site using HTML, customize it to fit your style, and even link it to a custom domain.
Start your journey today and present your work to the world with confidence! If you have any question, feel free to drop a comment below.