This is a guide to assist with anyone who is looking to update their readme files or create new repos. If there are any updates, changes or alterations, please be sure to file an issue/pr to get that issue resolved.
- Headers
- Emphasis
- Lists
- Images
- Links
- Blockquotes
- Horizontal Rules
- Tabels
- Blackslash escape
- Task Lists
- Inline HTML
- Colapsable section
- Link to the top of the page or a specific section on said page
- Fenced Code Blocks
- Syntax highlighting
- Inline code
- Emoji
- Username @ mentions
- Issue References
- Hotkey
- Footnotes
- YouTube Videos
## Table Of Contents
* [Headers](#headers)
* [Emphasis](#emphasis)
* [Lists](#lists)
+ [Unordered](#unordered)
+ [Ordered](#ordered)
* [Images](#images)
* [Links](#links)
* [Blockquotes](#blockquotes)
* [Horizontal Rules](#horizontal-rules)
* [Tabels](#tabels)
* [Blackslash escape](#blackslash-escape)
* [Task Lists](#task-lists)
* [Inline HTML](#inline-html)
* [Colapsable section](#colapsable-section)
* [Link to the top of the page or a specific section on said page](#link-to-the-top-of-the-page-or-a-specific-section-on-said-page)
* [Fenced Code Blocks](#fenced-code-blocks)
* [Syntax highlighting](#syntax-highlighting)
+ [No highlighting](#no-highlighting)
+ [Highlighting](#highlighting)
+ [JavaScript Syntax](#javascript-syntax)
+ [Python Syntax](#python-syntax)
+ [HTML Syntax](#html-syntax)
+ [No Langauage](#no-langauage)
* [Inline code](#inline-code)
* [Emoji](#emoji)
* [Username `@` mentions](#username-----mentions)
* [Issue References](#issue-references)
* [Hotkey](#hotkey)
* [Footnotes](#footnotes)
* [YouTube Videos](#youtube-videos)
# This is an <h1> tag
## This is an <h2> tag
### This is an <h3> tag
#### This is an <h4> tag
##### This is an <h5> tag
###### This is an <h6> tag
*This text will be italic*
_This will also be italic_
**This text will be bold**
__This will also be bold__
~~This text will be crossed out (strikethrough)~~
_You **can** combine them_
***All this text is bold and italic***
This text will be italic This will also be italic
This text will be bold This will also be bold
This text will be crossed out (strikethrough)
You can combine them
All this text is bold and italic
* Item 1
* Item 2
* Item 2a
* Item 2b
- Item 1
- Item 2
- Item 2a
- Item 2b
1. Item 1
1. Item 2
1. Item 3
1. Item 3a
1. Item 3b
- Item 1
- Item 2
- Item 3
- Item 3a
- Item 3b
Note if you are looking to link images, it is advised to create a folder in the readme location labeled "Media" or "Images". This will help prevent the image from vanishing if uploaded any other way.
If you are running a repository that runs LFS (Large File Support), then you may run into issues uploading and displaying images. If this is the case you will need to modify the repo on the host end (GitHub) to allow uploading of these images.
Navigate to the ".gitattributes" file in the repo. Search for the files that you are using in the readme (Usually it will be png). Will look something like this
*.png filter=lfs diff=lfs merge=lfs -text
Copy and paste at the bottom of the text file including the file those images are stored in. For example;
Media/.png filter= diff= merge= -text or Images/.png filter= diff= merge= -text
Format: ![Alt Text](url)
Example: ![Newspaper Delivery Game](https://github.com/o3de/NewspaperDeliveryGame/blob/main/Media/image7.png)
If the image is located within folder tree that this readme is located in, you would then use the following:
Format: ![Alt Text](url)
Example: ![Newspaper Delivery Game](/Media/image01.png)
"Media" being the folder that your images are located in.
http://github.com - automatic!
http://github.com - automatic!
Format: [Test](url)
Example: [GitHub](http://github.com)
As Bruce Banner said:
> That’s my secret, Captain.
> I’m always angry.
As Bruce Banner said:
That’s my secret, Captain. I’m always angry.
Blockquotes can be nested.
> Dorothy followed her through many of the beautiful rooms in her castle.
>
>> The Witch bade her clean the pots and kettles and sweep the floor and keep the fire fed with wood.
Dorothy followed her through many of the beautiful rooms in her castle.
The Witch bade her clean the pots and kettles and sweep the floor and keep the fire fed with wood.
Horizontal rules can be created using three or more asterisks (***), dashes (---), or underscores (___) on a line by themselves.
***
----
______
| First Header | Second Header |
| ------------- | ------------- |
| Content Cell | Content Cell |
| Content Cell | Content Cell |
First Header | Second Header |
---|---|
Content Cell | Content Cell |
Content Cell | Content Cell |
| Left-aligned | Center-aligned | Right-aligned |
| :--- | :---: | ---: |
| git status | git status | git status |
| git diff | git diff | git diff |
Left-aligned | Center-aligned | Right-aligned |
---|---|---|
git status | git status | git status |
git diff | git diff | git diff |
Your Markdown does't have to be pretty.
There must be at least 3 dashes separating each header cell. The outer pipes (|
) are optional, and you don't need to make the table columns line up prettily.
Less | Pretty | Markdown
--- | --- | ---
1 | 2 | 3
*Still* | `renders` | **as expected**
4 | 5 | 6
Less | Pretty | Markdown |
---|---|---|
1 | 2 | 3 |
Still | renders |
as expected |
4 | 5 | 6 |
Markdown allows you to use backslash escapes to generate literal characters which would otherwise have special meaning in Markdown’s formating syntax.
Name | Markdown | Result |
---|---|---|
backslash | \\ |
\ |
backtick | \` |
` |
asterisk | \* |
* |
underscore | \_ |
_ |
curly braces | \{\} |
{} |
square brackets | \[\] |
[ ] |
parentheses | \(\) |
() |
hash mark | \# |
# |
plus sign | \+ |
+ |
minus sign (hyphen) | \- |
- |
dot | \. |
. |
exclamation mark | \! |
! |
- [x] this is a complete item
- [ ] this is an incomplete it
- [ ] A subtask
- this is a complete item
- this is an incomplete it
- A subtask
Markdown also supports raw HTML.
<dl>
<dt>First Term</dt>
<dd>This is the definition of the first term.</dd>
<dt>Second Term</dt>
<dd>This is one definition of the second term. </dd>
<dd>This is another definition of the second term.</dd>
</dl>
- First Term
- This is the definition of the first term.
- Second Term
- This is one definition of the second term.
- This is another definition of the second term.
<p>Markdown in HTML does *not* work **well**. Use <i>HTML</i> <b>tags</b> instead.</p>
Markdown in HTML does *not* work **well**. Use HTML tags instead.
Title 1
Content 1 Content 1 Content 1 Content 1 Content 1
Title 2
Content 2 Content 2 Content 2 Content 2 Content 2
<details>
<summary>Title 1</summary>
<p>Content 1 Content 1 Content 1 Content 1 Content 1</p>
</details>
[Go To TOP](#table-of-contents)
<a name="table-of-contents"></a>
[a Name](#Section-ID)
<a name="Section-ID></a>
You can create fenced code blocks by placing triple backticks ```
before and after the code block. We recommend placing a blank line before and after code blocks to make the raw formatting easier to read.
function test() {
console.log("notice the blank line before this function?");
}
To display triple backticks in a fenced code block, wrap them inside quadruple backticks.
````
```
Look! You can see my backticks.
```
````
```
Look! You can see my backticks.
```
You can add an optional language identifier to enable syntax highlighting in your fenced code block.
For example, to syntax highlight Ruby code:
```ruby
require 'redcarpet'
markdown = Redcarpet.new("Hello World!")
puts markdown.to_html
```
require 'redcarpet'
markdown = Redcarpet.new("Hello World!")
puts markdown.to_html
```
if (isAwesome){
return true
}
```
if (isAwesome) {
return true
}
```markdown
var s = "JavaScript syntax highlighting";
alert(s);
```
var s = "JavaScript syntax highlighting";
alert(s);
```javascript
if (isAwesome){
return true
}
```
if (isAwesome) {
return true
}
```javascript
var s = "JavaScript syntax highlighting";
alert(s);
```
var s = "JavaScript syntax highlighting";
alert(s);
```python
s = "Python syntax highlighting"
print s
```
s = "Python syntax highlighting"
print s
``` html
<p><pre><code class="language-html"><p>HTML Document</p>
</code></pre></p>
```
<p><pre><code class="language-html"><p>HTML Document</p>
</code></pre></p>
```
No language indicated, so no syntax highlighting.
But let's throw in a <b>tag</b>.
```
No language indicated, so no syntax highlighting.
But let's throw in a <b>tag</b>.
You can have list/line code sections as well.
Title
----
- Line1
```bash
ls
```
- Line2
```bash
ls -l
```
- Line1
ls
- Line2
ls -l
- Line2
I think you should use an `<addr>` element here instead.
I think you should use an <addr>
element here instead.
Markdown coverts text with four leading spaces into a code block; with GFM you can wrap your code with
Look up emoji codes at emoji-cheat-sheet.com
:+1: :sparkles: :camel: :tada: :rocket: :metal:
👍 ✨ 🐫 🎉 🚀 🤘
Typing an @ symbol, followed by a username, will notify that person to come and view the comment. This is called an “@mention”, because you’re mentioning the individual. You can also @mention teams within an organization
Any number that refers to an Issue or Pull Request will be automatically converted into a link. Note this issue has to be located from within the repository that you are doing your work in. #1
⌘F
⇧⌘F
<kbd>⌘F</kbd>
Hotkey list:
Key | Symbol |
---|---|
Option | ⌥ |
Control | ⌃ |
Command | ⌘ |
Shift | ⇧ |
Caps Lock | ⇪ |
Tab | ⇥ |
Esc | ⎋ |
Power | ⌽ |
Return | ↩ |
Delete | ⌫ |
Up | ↑ |
Down | ↓ |
Left | ← |
Right | → |
Footnotes aren't part of the core Markdown spec, but they supported by GFM.
A footnote can also have multiple lines[^2].
You can also use words, to fit your writing style more closely[^note].
[^1]: My reference.
[^2]: Every new line should be prefixed with 2 spaces.
This allows you to have a footnote with multiple lines.
[^note]:
Named footnotes will still render with numbers instead of the text but allow easier identification and linking.
This footnote also has been made with a different syntax using 4 spaces for new lines.
Reners to:
They can't be added directly but you can add an image with a link to the video like this:
<a href="http://www.youtube.com/watch?feature=player_embedded&v=YOUTUBE_VIDEO_ID_HERE
" target="_blank"><img src="http://img.youtube.com/vi/YOUTUBE_VIDEO_ID_HERE/0.jpg"
alt="IMAGE ALT TEXT HERE" width="240" height="180" border="10" /></a>
Or, in pure Markdown, but losing the image sizing and border:
[![IMAGE ALT TEXT HERE](http://img.youtube.com/vi/YOUTUBE_VIDEO_ID_HERE/0.jpg)](http://www.youtube.com/watch?v=YOUTUBE_VIDEO_ID_HERE)