CodeNewbie Community 🌱

Pauline
Pauline

Posted on • Originally published at dev.to on

Getting started | The ultimate junior developer survival guide

Welcome to the ultimate junior web developer survival guide! This guide is a series of multiple posts where I document and share some of my most valuable experiences, advice, learnings, lessons, answers to questions my past self had, mistakes I made (so that you don’t have to make them), and much more in an attempt to simplify and improve your life as a junior developer as much as I can.

I will be talking about non-technical matters that you learn on the job. The articles will be relatively short and concise so you spend less time reading and more time executing. 🙌🏻

Ready? Let's go!

1. Learn how to ask questions

Asking for help can be hard. And once you succeed reaching out, asking the right questions is even harder. It’s key to prepare your questions and sketch the situation as clearly as possible to outsiders.

I like to use the format below whenever I ask for help:

  • Share the context. Which feature are you working on? What is the desired outcome?
  • What is the problem you're trying to solve?
  • Which solutions have you tried?

Try to be as specific as possible with your questions. Rather than bluntly asking your colleague or peer “Why does this code not work?” out of nowhere, try something like “I’m trying to render the data from my API call here and have tried out solutions X and Y. I suspect the problem lies in this part of the code, but I'm not 100% sure. Could you explain why this approach I tried does not solve problem Z here? Do you know what could be going wrong here?”.

Gordon Zhu has written an excellent piece on asking great questions in which he shares a thorough outline of steps to take to get better at requesting and receiving help. I found this article very helpful and I encourage you to check it out too.

2. Take notes

As developers, we are learning new things every single day. With so much new information non-stop coming our way, we shouldn’t always be relying on our memory to retain all of it. Do your future self a huge favour and take notes (even if no one else around you is doing it)!

Spoiler alert: every time you catch yourself thinking "I don't need to write it down, I'll definitely remember this next time", chances are 99.9% you're going to forget it.

If you work through a bug or problem where you got stuck or faced some difficulty, recap and document the solution. Our brains are solving so many problems on a daily basis and we very easily forget certain solutions, even if they made sense the first time we encountered them (I know I’m not the only one). Had to Google or StackOverflow something and feel like it may come in handy again later? Jot it down. This doesn’t have to be some official or formal documentation for others to read — they're simply notes for your future self. It doesn’t matter if you take notes digitally or use pen and paper.

Documenting your solutions and learnings does not only serve as a future reference guide, but it’s also a great way to keep a log of things you learned along the way (and therefore indirectly tracking your progress so you can see how far you've come!). You will thank yourself later. 🎉

3. Set up knowledge-sharing sessions with more experienced developers

When I started my first internship/developer job, I found it very helpful to block time to discuss certain engineering topics and concepts with a more experienced colleague. This can be just 30-60 minutes where you sit down together to improve your own understanding of something.

You might be thinking now: “Uh.. shouldn’t I educate myself and study the topic on my own first, rather than asking my colleagues to be my tutor?”. Bear in mind that this is not a lecture where you just sit back and absorb theory. You are creating an opportunity to improve your knowledge and understanding (and let’s face it, thereby also increasing your value to the company). This then also allows you to see how certain theoretical concepts are applied in practice in the company’s codebase. On top of that, don’t forget that you’re also testing your colleague’s understanding of certain topics and helping them improve their communication skills. 😉

Select some topics you might struggle with (some topics I for example asked for help with were Git and JavaScript/React testing), dive into the topic and prepare a few questions. Which parts are unclear to you? It could also be a concept you encounter often, but still do not fully grasp yet. Invite other junior colleagues if you feel like it can be helpful for them too.


This is it for part 1, stay tuned for the next one! If there are any topics you are curious to read or learn more about, leave a comment or send me a message and I will try my best to cover it!

Top comments (3)

Collapse
 
larrymartin1job profile image
Larry Martin

Appreciate the insights shared here. Setting up knowledge sharing sessions sounds like a fantastic way to deepen understanding while fostering teamwork and communication skills among colleagues.
Home Cleaning Services in Bronx NY

Collapse
 
aaron profile image
Aaron McCollum

Thanks for posting this Pauline! I read this a few months ago and have started taking better notes when learning new things as a result of reading your article. Hope all is well.

Collapse
 
httpspauline profile image
Pauline

Hey Aaron, your comment made my day—I'm glad my article was helpful! Thank you so much for reading — I'll be posting more in the near future so definitely keep an eye out (or if there's anything you'd like to read about, let me know) 🙌