Welcome to Svelte Blog, an example of a simple yet visually appealing blog created with Svelte and SvelteKit. This project utilizes markdown files for articles and integrates Tailwind CSS for styling.
The idea is to have the simplest blog possible, where one article = one file.
You can see a live version of this blog here: ICONO blog
Before getting started, make sure you have the following dependencies installed:
- Mdsvex: Used to process markdown files.
- Tailwind CSS: Provides utility classes for styling.
- Clone this repository:
git clone https://github.com/adrienlf/svelte-blog.git
- Navigate to the project directory:
cd svelte-blog
- Install dependencies:
npm install
- Run the project:
npm run dev
- Open your browser and go to:
http://localhost:5173/
The main functionality can be found at the route/blog
route and within the lib/assets/components/blog
directory.
svelte-blog/src/routes/api/posts/+server.js
: Retrieves.md
files insvelte-blog/src/routes/blog
. You can modify this to suit your needs.svelte-blog/src/lib/assets/components/blog/BlogPreview.svelte
: Displays articles as cards on the main blog page.svelte-blog/src/lib/assets/components/blog/BlogList.svelte
: Displays links to articles on the article page.svelte-blog/src/routes/blog/+layout.svelte
: Contains a simple header for the blog layout.svelte-blog/src/routes/blog/+page.svelte
: Renders articles with a customizable style.
To add new articles to your Svelte Blog, follow the structure provided below in your Markdown files:
---
title: Post Title
date: "YYYY-MM-DD"
slug: unique-slug-for-the-post
preview: Brief preview of the article.
previewImage: URL-to-preview-image
quote: "A catchy quote from the article."
---
We welcome contributions to improve these components and enhance the project. If you're new to Svelte and SvelteKit, this could be a great learning opportunity.
Feel free to use the components as they are or modify them according to your needs. If you make any improvements, consider opening a pull request to share your changes with the community.