Add image to hugo site
In Hugo, you can add images to your page in several ways depending on where your images are stored. Here are the main methods:
1. Using Page Bundles (Recommended)
If you’re using page bundles, place the image inside the same folder as your markdown file.
Steps:
- Place the image inside the same directory as the markdown file:
content/posts/my-post/ ├── index.md ├── my-image.jpg
- In
index.md
, reference the image using:ordata:image/s3,"s3://crabby-images/e71f1/e71f117496bfed4a348191f2fea9985ff9744ebd" alt="Alt text"
data:image/s3,"s3://crabby-images/58304/5830494d68ea0f7147cd2b2ef58cd7893c321d0e" alt="Alt text"
2. Using the static/
Directory
If you prefer to store images globally, place them in the static/
directory.
Steps:
- Place your image in:
static/images/
- Reference the image in your markdown file:
data:image/s3,"s3://crabby-images/25b20/25b2062408f80e9853de39b7ce932005cdd1449a" alt="Alt text"
3. Using Hugo Shortcodes for More Control
Hugo provides a built-in figure
shortcode for more control (e.g., adding captions).
data:image/s3,"s3://crabby-images/e71f1/e71f117496bfed4a348191f2fea9985ff9744ebd" alt="Alt text"
Image Title
If the image is in static/images/
, use:
data:image/s3,"s3://crabby-images/25b20/25b2062408f80e9853de39b7ce932005cdd1449a" alt="Alt text"
Image Title
4. Using Markdown with Absolute URLs
If your image is hosted externally (e.g., on a CDN or image hosting service), use:
data:image/s3,"s3://crabby-images/8fa1c/8fa1c1bd88ca55eb66579e196eef6366421e1a47" alt="Alt text"
5. Using HTML for More Customization
For more control (e.g., setting custom sizes):
<img src="/images/my-image.jpg" alt="Alt text" width="600">
Which Method to Use?
- For blog posts: Use Page Bundles (
content/posts/my-post/index.md
). - For global images: Use the static folder (
static/images/
). - For captions and styling: Use Hugo shortcodes.
- For external images: Use absolute URLs.
Let me know if you need further help! 🚀