A portfolio website is something most developers will attempt to build at some point in their careers. It can be a great tool for finding customers, getting hired, and showcasing your work, technical skills and know-how.
Many developers create stunning portfolio websites, some of which even end up going viral. However, others create portfolio websites that end up being more of a hindrance than an advantage. Below are some Do's and Don'ts that will hopefully help you build a better portfolio website.
DO plan ahead
A failure to plan is a plan to fail. Before you even think about opening your code editor, you need to have a clear plan. Visualize what you want your website to look like. What color scheme and font will you use? What sections do you want to include? How will you describe yourself and your work? What kind of images will you need, if any?
After you answer all of these questions, open a new Figma or Adobe XD design file, or whatever your preferred design tool is, or simply grab a pen and paper. Start sketching out the image you've created in your head. Play around with the design until you're happy with what you see.
Only at this point should you start coding. Now it will be much faster to translate your design into code, and you'll find yourself going back and forth much less than if you had dived straight into coding.
DO have a clean and consistent design
Many portfolio websites come with brash colors, inconsistent spacing and font sizes, or are simply messy and unorganized. Unless you're into brutalist design, this is not something you want.
While you're in the planning phase, do some research about what constitutes good design. Find a good combination of colors and stick to it. Set some typography and spacing rules for yourself and follow them religiously.
One way to make this easier for yourself is to use a CSS framework or library, such as Tailwind CSS, Material UI, Bootstrap and so on. These tools will already have design systems pre-implemented, and they follow patterns that are tried and true.
DO include the names of your skills
Sure, you and other developers might be aware that a light blue atom symbol stands for React.js, or that a single green leaf stands for MongoDB. But if your goal is to find clients or a job, you need to think a little more about your target audience.
Hiring managers or potential clients might not be familiar with all of the technologies in your skillset, and they might not recognize their logos at first glance. For this reason, make sure you find a way to include the actual names of your skills.
DO showcase your work
Instead of simply including a link to your GitHub profile, consider showcasing some of your projects directly on your website. This makes it much easier for users to see what you're capable of, as they don't have to go to an external website and manually check your repositories.
The main things you should include when showcasing a project are:
a screenshot (if applicable)
the project's name
links to a live preview and to the GitHub repository
a short description of the functionality and/or the technologies used
DO include a call to action
A call to action is a well known marketing tool meant to prompt a user's response and increase their engagement. Whether you're looking for a job, clients or other developers to collaborate with, make sure you encourage your users to get in touch with you, and provide the means to do so.
DON'T overwhelm users with too many animations
Oftentimes, developers feel the need to showcase their animation skills to the max. This often means that they will have overly complex animations, or they will try to animate every single element of their web page.
Having too many or too complex animations will not only be incredibly distracting for your users, but it will also significantly impact the performance of your website, especially if they are not done correctly or your users aren't using the most high-end devices.
This doesn't mean that you should not have a single animation on your website. On the contrary, if you're good at it, show it! But do be careful not to go overboard. Your priority should be the content of your page. It would be much better to have a separate project where you can go as crazy as you want with all of your animation skills.
DON'T neglect accessibility and responsiveness
Your portfolio website should provide the best experience possible for all users. Make sure you learn about accessibility and try to incorporate at least some techniques that will make your page more accessible, not only for people with disabilities, but also for people who might have old devices, slow connections and so on.
In terms of responsiveness, keep in mind that almost 60% of web traffic happens on mobile devices. This means that on average, your users are more likely to be visiting your website from a mobile phone instead of a laptop or desktop computer.
A good approach is mobile-first design. This means that you build your website to look good on mobile devices first, and then you scale up to bigger screens. On a personal note, I find it easier to transform a small-screen design into a large-screen design, rather than the other way around.
DON'T ramble on forever
Writing about yourself, describing your work, calls to action - these are all important things to include in your portfolio website, but you should try to be as concise and to the point as possible.
There is no need to write your entire life story in your About section, or to describe in detail the trials and tribulations you went through while building your latest project. Your users will want to see you and your work at a glance, rather than read an entire essay. For lengthier texts, consider creating a blog section for your page.
DON'T clutter your work section
While showcasing your work is important, you don't need to overload your website with every single project you've ever built. Instead, stick to a few that you're most proud of, and provide a link to see the rest of your work (for example, a link to your GitHub profile).
DON'T set it and forget it
You've read a bunch of articles about creating your portfolio website, you've spent time planning and designing it, you've transformed your design into code, perfecting every single detail, you've found the perfect place to host your creation, perhaps you've even invested in a custom domain, and now your awesome portfolio is out there for the world to see! Done, right? Wrong!
Your portfolio website is something that you should always return to and update frequently. Learned a new skill? Update your website. Built a new project? Update your website. The list goes on. Your portfolio website is a reflection of yourself. Make sure it always reflects the present you, not the past you.
Conclusion
These have been my ten tips to keep in mind when creating your portfolio website. Many of these are based simply on my own opinions and on the feedback I've received while building my own portfolio website. Let me know if you've learned something useful from my article, or if you've implemented some of my tips in your own portfolio websites. π
Top comments (37)
Really great article and solid advice. π
From my own experience a DONβT that I always recommend is βdonβt use progress bars nor percentages against your list of skills.β For example:
This is problematic because the values are too subjective. Does the above mean you know 99% of the CSS spec (even the draft spec) by rote? How do you measure that 5% difference between JS and TS? And how do you compare 80% βskillβ in a design tool (Figma) against βskillβ in a scripting language (JS)?
In my experience, itβs better to just list the skills and then show (rather than tell) your skill through your well developed and designed portfolio site and accompanying body of work.
Came to say this!
Also please no more typewriter animation
Hey!
It was trendy a couple of years ago, I know I need to redo my portfolio but this isn't gonna happen anytime soon, stop reminding me about it πππ
I was trying to make portfolio(retro-style) website for the first time, and I did typing animation because that seemed good for me and also I added the progress bars for the skills section. So yeah I did almost everything you said not to do
Yes. And why would you downplay yourself?
Well said, I totally agree!
What about rating skills out of 5?
For example Javascript 3/5
A fraction is just another way of writing a percentage (or a progress bar):
3/5 = 60% = ββββββββββ
In my experience, you are better off listing JavaScript skills you are proficient in, and then providing examples of work that reflect those skills.
For example, you might highlight your skills with async/await and interacting with REST APIs. You could show this by including a project that demonstrates your understanding, such as a static blog that generates its pages from the dev.to API.
Neat Article Ioana. I created my portfolio site 3-4 months back. I think it follows most of the "Do's" that you have mentioned. Can I have some feedback on it please !
shammisharma.netlify.app
Thanks.
Looks nice and clean! I wouldn't change anything, I think it does the job really well. I like the scrolling preview in your websites section. π
Thank you for your feedback Ioana. I'm glad you liked it.
It looks great.
Congratulations!
Good advice, totally agree!
I will add that redoing from scratch your portfolio is an option and in my case most of the time it's an "easy" project that shows me how I've improved since the last time I tried.
So if someone detects some red flags in their portfolio after reading this article, they can adjust it but if they did it a long time ago, it's totally fine to think about a new version.
One small nuance, don't use this as an excuse to build an unmaintainable portfolio :D
Great content
Thank you! I love reading various Do's and Don'ts, they're usually very informative :)
Witch one do you prefer to use for blog. Dark or light mode?
I personally prefer using dark mode anywhere I can. π
Best usability is giving the reader a choice! I am going to rework my (light mode) site so that users can choose dark/light/low-contrast modes, and, automatically read what the user's preference is via the browser so the site defaults to the mode they want without them needing to select it on the screen
Thanks, for advices. I have 30+ years working experience (tons of different places, designer -> developer). So I simplify to whole portfolio to a single page CV ... really minimalist design. Plus link to one of my npm modules: react-troll with this sentence:
This will lead the interview to my well known area.
Good advise.
One of the few DEV articles I've seen have actual care and effort put into it.
Nice job authoring this!
Thank you, it was lots of fun to write. π
Well I look forward to seeing future if you have plans to post more.
(Also I know this isn't the place, but welcome to DEV.)
Thank you, I definitely plan on posting more in the future! π
Hello Ioana Tiplea,
thank you for your article.
It was an easy read for me and I like how you show an example of things you recommend.
I also like the link which shows that mobile accounts for almost 60% of web traffic. This makes it not just a simple claim.
I also like that some terms link to websites that explain them (e.g. "call to action").
Hey Akin, thank you for the feedback, I really appreciate it! π
Wow nice one, I love this
Thanks a lot. Here's my portfolio - harsh-singh.in. please do give your feedback on it. I have gone for an unconventional design, but something that is not very cluttered.
Very cool! All the required info to contact you is immediately visible, and your projects are only one click away. It all works really well with the style you've chosen. An example of an unconventional design that works!
Your ASCII art is only half visible on mobile (you have to scroll sideways to see the rest), but I have no idea if it's even possible to change that. π€
Thank you for the feedback π. I will try to improve the Ascii art so that it is also visible on mobile devices. I can reduce the font size or break the two words and display them on two different lines.
Aahhh, no Mx employer person, I have ten years of experience in Animal Crossing, not MongoDB.
I see the confusion.
Β Β Β Β /j
Lol, final interview round: recruiter visits your town.
This is literally the interview process for being a full-time gamer. :ΓΎ
That last one... hurts πππ
I did this in may 2020
Building an efficient portfolio from scratch.
JoelBonetR γ» May 23 '20 γ» 17 min read
And didn't edited it again π³
Maybe you should π
Nevermind I'll re-do the entire thingy at any point π
Incredible adviceππ»
Feedback required on my portfolio website dev nation,
ayushseth.netlify.app/
Appreciated!