快速上手

先看在线效果

动手搭建之前,强烈建议先打开在线 Demo: sveltepress.github.io/sveltepress/blog-demo 。本页介绍的一切特性都已经在这里跑起来了。

源码在 monorepo 中的 packages/example-blog 。克隆仓库、执行 pnpm install && pnpm dev,你就能在 localhost:4173 得到一份可直接运行的参考实现。

@sveltepress/theme-blog 是一款杂志风格的博客主题,自带左侧边栏、瀑布流文章网格、自动生成的单篇 OG 图片、RSS、Pagefind 搜索和 Giscus 评论。本页演示如何从零搭建一个可运行的博客。

安装

pnpm add -D @sveltepress/vite @sveltepress/theme-blog @sveltejs/kit @sveltejs/adapter-static svelte vite
bash

主题依赖 @sveltejs/adapter-static,因为它会生成完全静态的站点(预渲染 HTML、JSON、RSS 与 OG 图片)。

配置 Vite

vite.config.ts
import {  } from '@sveltepress/theme-blog'
import {  } from '@sveltepress/vite'
import {  } from 'vite'

export default ({
  : [
    ({
      : ({
        : 'My Blog',
        : 'Thoughts on Svelte and the web.',
        : 'https://example.com',
        : {
          : 'Your Name',
          : '/avatar.png',
          : '侧边栏展示的简短介绍。',
          : {
            : 'your-handle',
            : 'your-handle',
            : '/rss.xml',
          },
        },
        : [
          { : '首页', : '/' },
          { : '时间线', : '/timeline/' },
          { : '标签', : '/tags/' },
        ],
      }),
    }),
  ],
})
ts

配置 SvelteKit

svelte.config.js
import adapter from '@sveltejs/adapter-static'
import { vitePreprocess } from '@sveltejs/vite-plugin-svelte'

export default {
  extensions: ['.svelte'],
  preprocess: [vitePreprocess()],
  kit: {
    adapter: adapter({
      pages: 'dist',
      assets: 'dist',
      fallback: '404.html',
    }),
    prerender: {
      handleMissingId: 'ignore',
      handleUnseenRoutes: 'ignore',
    },
    paths: {
      base: process.env.BASE_PATH ?? '',
      relative: false,
    },
  },
  compilerOptions: {
    runes: true,
  },
}
js

BASE_PATH 用于在子路径下部署(例如 GitHub Pages 的项目站点)。根路径部署时保持该环境变量未设置即可。

写第一篇文章

新建 src/posts/hello-world.md

src/posts/hello-world.md
---
title: Hello world
date: 2026-04-17
tags: [intro]
category: meta
excerpt: 博客的第一篇文章。
---

# Hello

欢迎来到我的博客。一切都是 Markdown。
md

自动生成的路由

下次执行 vite devvite build 时,主题会在这些文件不存在时写入它们。你可以自由编辑——脚手架只创建缺失的文件。

路径作用
src/routes/+layout.ts启用预渲染并设置 trailingSlash: 'always'
src/routes/+layout.svelteGlobalLayout 包裹所有页面
src/routes/+page.{server.ts,svelte}分页的首页
src/routes/page/[n]/...第 2 页及之后的列表
src/routes/posts/[slug]/...单篇文章页
src/routes/tags/+page.svelte标签索引
src/routes/tags/[tag]/...按标签过滤的文章
src/routes/categories/[cat]/...按分类过滤的文章
src/routes/timeline/+page.svelte归档时间线

构建

pnpm vite build && pnpm pagefind --site dist
bash

Pagefind 步骤会对构建产物建立索引,以便搜索弹窗(⌘K / Ctrl+K)能正常工作。如果你不用搜索可以跳过这一步。

最终的 dist/ 是一个可以部署到任意静态主机的静态站点。

最后更新于: 2026/04/17 03:36:00