DEV Community

Cover image for Do's and Don'ts of Creating Your Portfolio Website
Ioana Tiplea
Ioana Tiplea

Posted on • Originally published at blog.ioanatiplea.dev

Do's and Don'ts of Creating Your Portfolio Website

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.

image-20220820172525195

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

image-20220820175617839

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.

image-20220820180037390


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).

image-20220820183132271

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)

Collapse
 
danwalsh profile image
Dan Walsh

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:

  • JavaScript - 95%
  • HTML - 99%
  • CSS - 99%
  • TypeScript - 90%
  • Figma - 80%

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.

Collapse
 
joeattardi profile image
Joe Attardi

Came to say this!

Also please no more typewriter animation

Collapse
 
joelbonetr profile image
JoelBonetR πŸ₯‡

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 πŸ˜‚πŸ˜‚πŸ˜‚

Collapse
 
ioutis profile image
Mohd Mushtaq

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

Collapse
 
horosin profile image
Karol Horosin

Yes. And why would you downplay yourself?

Collapse
 
ioanat94 profile image
Ioana Tiplea

Well said, I totally agree!

Collapse
 
unknowngry profile image
Ryan Medina

What about rating skills out of 5?
For example Javascript 3/5

Collapse
 
danwalsh profile image
Dan Walsh • Edited

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.

Collapse
 
shammisharma profile image
shammisharma • Edited

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.

Collapse
 
ioanat94 profile image
Ioana Tiplea

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. 😊

Collapse
 
shammisharma profile image
shammisharma

Thank you for your feedback Ioana. I'm glad you liked it.

Collapse
 
drfcozapata profile image
Francisco Zapata

It looks great.
Congratulations!

Collapse
 
dastasoft profile image
dastasoft

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

Collapse
 
darlio profile image
Darlio88

Great content

Collapse
 
creative_fuel22 profile image
Pauline Al

Thank you! I love reading various Do's and Don'ts, they're usually very informative :)

Collapse
 
r124ltech profile image
Rizal Iswandy

Witch one do you prefer to use for blog. Dark or light mode?

Collapse
 
ioanat94 profile image
Ioana Tiplea

I personally prefer using dark mode anywhere I can. πŸ‘

Collapse
 
ruthmoog profile image
ruthmoog

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

Collapse
 
pengeszikra profile image
Peter Vivo • Edited

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:

My favourite framework is react, with redux-saga, but without redux.

This will lead the interview to my well known area.

Collapse
 
calinzbaenen profile image
Calin Baenen

Good advise.

One of the few DEV articles I've seen have actual care and effort put into it.
Nice job authoring this!

Collapse
 
ioanat94 profile image
Ioana Tiplea

Thank you, it was lots of fun to write. 😊

Collapse
 
calinzbaenen profile image
Calin Baenen

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.)

Thread Thread
 
ioanat94 profile image
Ioana Tiplea

Thank you, I definitely plan on posting more in the future! 😊

Collapse
 
incrementis profile image
Akin C.

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").

Collapse
 
ioanat94 profile image
Ioana Tiplea

Hey Akin, thank you for the feedback, I really appreciate it! 😊

Collapse
 
emerie55 profile image
Innocent Chiemerie Feargod

Wow nice one, I love this

Collapse
 
theharshsingh profile image
Harsh Singh

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.

Collapse
 
ioanat94 profile image
Ioana Tiplea

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. πŸ€”

Collapse
 
theharshsingh profile image
Harsh Singh

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.

Collapse
 
calinzbaenen profile image
Calin Baenen • Edited

or that a single green leaf stands for MongoDB.

Aahhh, no Mx employer person, I have ten years of experience in Animal Crossing, not MongoDB.
I see the confusion.
Β Β Β Β /j

Collapse
 
ioanat94 profile image
Ioana Tiplea

Lol, final interview round: recruiter visits your town.

Collapse
 
calinzbaenen profile image
Calin Baenen

This is literally the interview process for being a full-time gamer. :ΓΎ

Collapse
 
joelbonetr profile image
JoelBonetR πŸ₯‡

That last one... hurts πŸ˜‚πŸ˜‚πŸ˜‚

I did this in may 2020

And didn't edited it again 😳

Collapse
 
ioanat94 profile image
Ioana Tiplea

Maybe you should πŸ‘€

Collapse
 
joelbonetr profile image
JoelBonetR πŸ₯‡

Nevermind I'll re-do the entire thingy at any point πŸ˜…

Collapse
 
mandy32 profile image
Andrew mandela

Incredible adviceπŸ‘ŠπŸ»

Collapse
 
imayushseth profile image
Ayush Seth

Feedback required on my portfolio website dev nation,
ayushseth.netlify.app/
Appreciated!