paint-brush
🚀 5 Professional Tips for Crafting a Winning README! 🥊 by@bap
215 reads

🚀 5 Professional Tips for Crafting a Winning README! 🥊

by Baptiste FernandezDecember 8th, 2023
Read on Terminal Reader
Read this story w/o Javascript
tldt arrow

Too Long; Didn't Read

Your GitHub README is crucial for making a lasting impression on new visitors. This guide covers the fundamental building blocks of a killer README, including the importance of a memorable project name, a concise introduction, a well-organized table of contents, clear installation instructions, a user guide/demo, documentation/help center, contribution guidelines, acknowledgments, contact information, and licensing details. Learn how to beautify your README with logos, badges, and icons, and discover advanced tips like interactive content, Markdown mastery, and leveraging pre-made templates. Unleash the potential of your project with an outstanding README!

Company Mentioned

Mention Thumbnail
featured image - 🚀 5 Professional Tips for Crafting a Winning README! 🥊
Baptiste Fernandez HackerNoon profile picture


Hi friends 👋


Today, let's look at how to write a KILLER GitHub README file.


Image description

The README is the first touch point with anyone new to your repo.


A well-developed README can inform, engage, and invite participation.


This is particularly useful when you’re launching a new project or at times when it is critical that developers engage with your repo.


A good example of this is when you submit a repo to Quine's Creator Quests, which is a new type of open-source “bounty” that rewards developers for creating cool new repos that the community loves.


In a Creator Quest, having a well-written README could literally help you take a prize home. 💸



1️⃣ README... What is it? 🔮


The README file, usually a .txt or .md file, is the most important file in the project. It is the landing page of your open-source project and is the most visible piece of documentation.

Here's an example of a README from the Hoppscotch project.


Image description

Your README is where you set the tone for your project.


This is why there are a couple of elements that should be included. ⬇️



2️⃣ The 10 Building Blocks 🧱


READMEs can be written in various ways; some better than others.

Below are the main types of sections you should be able to find in a professional README.

If the below buckets are relevant to your project, I recommend you try to add these into your README. 👇


1. Coming up with a name: A significant amount of repos don't have good names. Spending a bit of time thinking of a memorable name is always a good strategy.


2. Write an introduction: A summary explaining the purpose and target audience of your project.


3. Table of ContentsMany repos fail to add this section. A well-organized table of contents helps make your repo clear and understandable.


4. Prerequisites & Installation InstructionsList out the various step-by-step installation instructions.Clarity here is essential.


5. User Guide / Demo: This section focuses on how to use your project with examples and optional commands. One method I like is adding a screen recording of how to run the project and how any user could use it.


6. Documentation / Help Center: If you wrote a documentation, an FAQ or a space that can act as a Help Center, write about it or add the link to it here.


7. Contribute: Explain briefly how to Contribute to your file and add a link to your CONTRIBUTING.md file. Here or in a separate section, you can also take the opportunity to list your contributors and thank them.


8. Acknowledgements: Use or help obtain external resources. This section is needed only if it is relevant to your repo.


9. Contact information: If you are trying to grow your project and build collaboration, this section is very useful.


10. Permission Information: This refers to the type of license you have picked for your project. It is essential to clarify how others can use your content. 👍



3️⃣ Beautify it 💄

READMEs can be written in various text formats, with Markdown being the most common one.


Markdown allows you to use simple, plain-text syntax, enabling the creation of headers, lists, links, and other elements to make the document more readable and organized.


Markdown also supports HTML code, which widens the spectrum of things you can do. 👇


Logo

If you have built a logo for your project, adding it at the start of your README is standard practice.


To do this, add and modify the below code in your README:


<p align="center">
    <!--     You can add your logo in the _src_ below -->
    <img src="https://www.amug.com/wp-content/uploads/2016/09/you-logo-here-300x106.png" />
</p>


Enter fullscreen mode Exit fullscreen mode


Badges

You often find good READMEs to provide badges in their introductory section.

These can look like this:

As you can see, these highlight some areas the maintainer(s) want to shed light on.

Here's how you add static badges to your README:


<p align="center">
  <!-- You can add your badges here -->
  <!-- If you have never added badges, head over to https://img.shields.io/badges/static-badge, follow the instructions and generate URL links to add below -->
  <img src="https://img.shields.io/badge/STARS-20K-green"  />
  <img src="https://img.shields.io/badge/FORKS-15K-blue"  />
  <img src="https://img.shields.io/badge/npm-v.0.21.0-red"  />
  <img src="https://img.shields.io/badge/LICENSE-MIT-green"  />
</p>


Enter fullscreen mode Exit fullscreen mode


Note: There are advanced dynamic options we won't get into here.


Icons

Icons have grown quite prominent in recent years.


You can add them to your Contact Information or in your Tech Stack section. You can find an example of the icon for X (formerly Twitter) and Linkedin.


fernandezbap

https://img.shields.io/badge/LinkedIn-0077B5?style=for-the-badge&logo=linkedin&logoColor=white

To build your own:


1️⃣ Head over to this repo here

2️⃣ Find the Socials and/or Tech Stack you Copy its link

3️⃣ Paste the link into the href shown below


<p align="left">
<!--     Add your own socials inside "href" -->
<a href="https://twitter.com/fernandezbap" target="blank"><img align="center" src="https://img.shields.io/badge/X-000000?style=for-the-badge&logo=x&logoColor=white" alt="fernandezbap" /></a>
</p>
<p align="left">
<a href="https://www.linkedin.com/in/baptiste-fernandez-%E5%B0%8F%E7%99%BD-0a958630/" target="blank"><img src="https://img.shields.io/badge/LinkedIn-0077B5?style=for-the-badge&logo=linkedin&logoColor=white" alt="https://img.shields.io/badge/LinkedIn-0077B5?style=for-the-badge&logo=linkedin&logoColor=white"  /></a>
</p>


Enter fullscreen mode Exit fullscreen mode


4️⃣ Advanced Tips 🛠️

Interactive content 🎥

You can consider embedded videos or widgets for interactive content.


In the Demo section of your README, you can embed a video.


⭐️ TIP: Sometimes, videos' sizes are too large, and it makes more sense to upload the video on YouTube and then link things out.


If you want to make it more visual, here's the code to add a picture/video thumbnail that redirects to your Youtube video once you click on it.


<p align="center">
    <a href="THE LINK TO YOUR YOUTUBE VIDEO HERE">
        <img src="YOUR IMAGE/VIDEO THUMBNAIL SOURCE HERE"/>
    </a>
</p>


Enter fullscreen mode Exit fullscreen mode


Markdown Mastery ✨

There are many advanced Markdown features to make your README look good.


You can check out this cool repo that lists some of these features.


A particular one I like is the toggle list or more commonly known as the collapsible section.


They can be particularly useful to keep your README looking concise and slick. Here's an example:

Image description

Here's the MARKDOWN template to build your own toggle list:


    <details>
       <summary>Toggle List Example</summary>

        ### Heading
        1. ABC
        2. DEF
           * Hello
    </details>


Enter fullscreen mode Exit fullscreen mode



Bonus Tip 🎖️

If you want to give recognition to your contributors in the Contributors section, you should check out AllContributors.


You can leverage its bot to automatically add all your latest contributors to your README.

Here's an example of what you can get:


Image description

You should also check the Emoji Key Documentation, which enables you to categorize different types of contributions. ⚡️



5️⃣ Leverage Pre-Made Templates 📝

Are there websites that build READMEs for you? 🤔


Absolutely!


You can find a plethora of README generators out there.

I have scanned and picked out my favourite three for you:


1️⃣ README templates

2️⃣ReadME Generator by Vercel



My advice with these would be to use them as a foundation and then customize them. ⭐️


Do you have a README template for me? 👀

I got you friend. 🫶


You can find my ready-made template here.


Image description

To start using it:


1️⃣ Fork the repo

2️⃣ Hover to the Edit section of the README

3️⃣ Begin filling in your information ✍️


If you find this template useful, I'd be grateful if you could give it some love by starring it. 🌟



Creating a good README file is an important skill. 🛠️


How you build it can be a determining factor in your repo's success.


Make sure to share your project and its polished new README in the comments section!


You can also leverage this new skill to build cool coding projects and compete to get paid. 🙌


If that's of interest, log into Quine and discover Quests, a place to code, have fun and bag some awesome rewards! 💰


Image description

See you next week.


Your Hackernoon buddy,


Bap 💚


Also published here.