• 网站
  • 网址
  • 目录
  • 文章
  • 分类 & 标签
  • 日期 / 时间格式
  • 分页
  • 扩展
    • 包括或不包括目录和文件
    • 使用代替配置文件
    • 覆盖主题配置

    您可以在 _config.yml 中修改大部分的配置。

    网站

    参数描述
    title网站标题
    subtitle网站副标题
    description网站描述
    keywords网站的关键词。使用半角逗号 , 分隔多个关键词。
    author您的名字
    language网站使用的语言
    timezone网站时区。Hexo 默认使用您电脑的时区。时区列表。比如说:America/New_York, Japan, 和 UTC

    其中,description主要用于SEO,告诉搜索引擎一个关于您站点的简单描述,通常建议在其中包含您网站的关键词。author参数用于主题显示文章的作者。

    网址

    参数描述默认值
    url网址
    root网站根目录
    permalink文章的 永久链接 格式:year/:month/:day/:title/
    permalink_defaults永久链接中各部分的默认值
    pretty_urls改写 permalink 的值来美化 URL
    pretty_urls.trailing_index是否在永久链接中保留尾部的 index.html,设置为 false 时去除true
    网站存放在子目录

    如果您的网站存放在子目录中,例如 http://yoursite.com/blog,则请将您的 url 设为 http://yoursite.com/blog 并把 root 设为 /blog/

    例如:

    1. # 比如,一个页面的永久链接是 http://example.com/foo/bar/index.html
      pretty_urls:
      trailing_index: false
      # 此时页面的永久链接会变为 http://example.com/foo/bar/

    目录

    参数描述默认值
    source_dir资源文件夹,这个文件夹用来存放内容。source
    public_dir公共文件夹,这个文件夹用于存放生成的站点文件。public
    tag_dir标签文件夹tags
    archive_dir归档文件夹archives
    category_dir分类文件夹categories
    code_dirInclude code 文件夹,source_dir 下的子目录downloads/code
    i18n_dir国际化(i18n)文件夹:lang
    skip_render跳过指定文件的渲染。匹配到的文件将会被不做改动的复制到 public 目录中。您可使用 glob 表达式来匹配路径。

    例如:

    1. skip_render: "mypage/**/*"
      # 将会直接将 `source/mypage/index.html` 和 `source/mypage/code.js` 不做改动地输出到 'public' 目录
      # 你也可以用这种方法来跳过对指定文章文件的渲染
      skip_render: "_posts/test-post.md"
      # 这将会忽略对 'test-post.md' 的渲染
    提示

    如果您刚刚开始接触Hexo,通常没有必要修改这一部分的值。

    文章

    参数描述默认值
    new_post_name新文章的文件名称:title.md
    default_layout预设布局post
    auto_spacing在中文和英文之间加入空格false
    titlecase把标题转换为 title casefalse
    external_link在新标签中打开链接true
    external_link.enable在新标签中打开链接true
    external_link.fieldApplies to the whole site or post onlysite
    external_link.excludeExclude hostname. Specify subdomain when applicable, including www[]
    filename_case把文件名称转换为 (1) 小写或 (2) 大写0
    render_drafts显示草稿false
    post_asset_folder启动 Asset 文件夹false
    relative_link把链接改为与根目录的相对位址false
    future显示未来的文章true
    highlight代码块的设置
    highlight.enableEnable syntax highlighttrue
    highlight.auto_detectEnable auto-detection if no language is specifiedfalse
    highlight.line_numberDisplay line numbertrue
    highlight.tab_replaceReplace tabs by n space(s); if the value is empty, tabs won’t be replaced''
    相对地址

    默认情况下,Hexo生成的超链接都是绝对地址。例如,如果您的网站域名为example.com,您有一篇文章名为hello,那么绝对链接可能像这样:http://example.com/hello.html,它是绝对于域名的。相对链接像这样:/hello.html,也就是说,无论用什么域名访问该站点,都没有关系,这在进行反向代理时可能用到。通常情况下,建议使用绝对地址。

    分类 & 标签

    参数描述默认值
    default_category默认分类uncategorized
    category_map分类别名
    tag_map标签别名

    日期 / 时间格式

    Hexo 使用 Moment.js 来解析和显示时间。

    参数描述默认值
    date_format日期格式YYYY-MM-DD
    time_format时间格式HH:mm:ss
    use_date_for_updatedUse the date of the post in post.updated if no updated date is provided in the front-matter. Typically used with Git workflowtrue

    分页

    参数描述默认值
    per_page每页显示的文章量 (0 = 关闭分页功能)10
    pagination_dir分页目录page

    扩展

    参数描述
    theme当前主题名称。值为false时禁用主题
    theme_config主题的配置文件。在这里放置的配置会覆盖主题目录下的 _config.yml 中的配置
    deploy部署部分的设置
    meta_generatorMeta generator 标签。 值为 false 时 Hexo 不会在头部插入该标签

    包括或不包括目录和文件

    在 Hexo 配置文件中,通过设置 include/exclude 可以让 Hexo 进行处理或忽略某些目录和文件夹。你可以使用 glob 表达式 对目录和文件进行匹配。

    参数描述
    includeHexo 默认会忽略隐藏文件和文件夹(包括名称以下划线和 . 开头的文件和文件夹,Hexo 的 _posts_data 等目录除外)。通过设置此字段将使 Hexo 处理他们并将它们复制到 source 目录下。
    excludeHexo 会忽略这些文件和目录

    举例:

    1. # Include/Exclude Files/Folders
      include:
      - ".nojekyll"
      # 包括 'source/css/_typing.css'
      - "css/_typing.css"
      # 包括 'source/_css/' 中的任何文件,但不包括子目录及其其中的文件。
      - "_css/*"
      # 包含 'source/_css/' 中的任何文件和子目录下的任何文件
      - "_css/**/*"

      exclude:
      # 不包括 'source/js/test.js'
      - "js/test.js"
      # 不包括 'source/js/' 中的文件、但包括子目录下的所有目录和文件
      - "js/*"
      # 不包括 'source/js/' 中的文件和子目录下的任何文件
      - "js/**/*"
      # 不包括 'source/js/' 目录下的所有文件名以 'test' 开头的文件,但包括其它文件和子目录下的单文件
      - "js/test*"
      # 不包括 'source/js/' 及其子目录中任何以 'test' 开头的文件
      - "js/**/test*"
      # 不要用 exclude 来忽略 'source/_posts/' 中的文件。你应该使用 'skip_render',或者在要忽略的文件的文件名之前加一个下划线 '_'
      # 在这里配置一个 - "_posts/hello-world.md" 是没有用的。

    列表中的每一项都必须用单引号或双引号包裹起来。

    includeexclude 并不适用于 themes/ 目录下的文件。如果需要忽略 themes/ 目录下的部分文件或文件夹,可以在文件名之前添加下划线 _

    使用代替配置文件

    可以在 hexo-cli 中使用 —config 参数来指定自定义配置文件的路径。你可以使用一个 YAML 或 JSON 文件的路径,也可以使用逗号分隔(无空格)的多个 YAML 或 JSON 文件的路径。例如:

    1. # use 'custom.yml' in place of '_config.yml'
      $ hexo server --config custom.yml

      # use 'custom.yml' & 'custom2.json', prioritizing 'custom3.yml', then 'custom2.json'
      $ hexo generate --config custom.yml,custom2.json,custom3.yml

    当你指定了多个配置文件以后,Hexo 会按顺序将这部分配置文件合并成一个 _multiconfig.yml。如果遇到重复的配置,排在后面的文件的配置会覆盖排在前面的文件的配置。这个原则适用于任意数量、任意深度的 YAML 和 JSON 文件。

    例如,使用 —options 指定了两个自定义配置文件:

    1. $ hexo generate --config custom.yml,custom2.json

    如果 custom.yml 中指定了 foo: bar,在 custom2.json 中指定了 "foo": "dinosaur",那么在 _multiconfig.yml 中你会得到 foo: dinosaur

    覆盖主题配置

    通常情况下,Hexo 主题是一个独立的项目,并拥有一个独立的 _config.yml 配置文件。你可以在站点的 _config.yml 配置文件中配置你的主题,这样你就不需要 fork 一份主题并维护主题独立的配置文件。

    以下是一个覆盖主题配置的例子:

    1. # _config.yml
      theme_config:
      bio: "My awesome bio"
    1. # themes/my-theme/_config.yml
      bio: "Some generic bio"
      logo: "a-cool-image.png"

    最终主题配置的输出是:

    1. {
      bio: "My awesome bio",
      logo: "a-cool-image.png"
      }