Home Page
TIP
In order to meet more usage scenarios of users, the theme has modularized the home page. Users can specify the content modules to be displayed and their display order in the frontmatter
of the md file of the home page. More modules will be developed later for everyone to use , and supports users to customize the home page module as needed.
Configure
Currently, the built-in homepage modules include Banner
, BannerBrand
, Features
, Blog
, MdContent
, Comment
, Footer
, and their configurations are as follows:
modules
- description: Specify the home page module
- default:
['BannerBrand', 'Blog', 'Footer']
- optional:
Banner
、BannerBrand
、Features
、Blog
、MdContent
、Comment
、Footer
- configuration item:
- Banner: Huge display map, can display logo, title, brief description, background image, top and bottom layout
- BannerBrand: Huge display map in brand format, which can display logo, title, brief description, background image, button, left and right layout
- Blog: Blog module, two-column layout, showing the list of blogs as a rule, and displaying user information and blog-related content on the right
- MdContent: The markdown text display module of the home page
- Comment: Comment Module
- Footer: Home Bottom Module
banner
- description: Used to configure the
Banner
module - frontmatter options:
- heroText: title
- tagline: Briefly
- heroImage: index logo
- heroImageStyle: index logo style
- bgImage: Background image
- bgImageStyle: Background image style
- case:
bannerBrand
- description: Used to configure the
BannerBrand
module - frontmatter options:
- title: Title
- descrition: Descrition
- tagline: tagline
- bgImage: Background image
- bgImageStyle: Background image style
- buttons: button
- text: button text
- link: content link
- type: content style, the default background color, if not needed, can be set to 'plain'
- socialLinks: For social address, See here for settings
- icon: icon
- link: button link
- case:
blog
- description: Used to configure the
Blog
module - frontmatter options:
- socialLinks: For social address, See here for settings
- icon: icon
- link: button link
- socialLinks: For social address, See here for settings
- themeConfig options:
- author: author name
- authorAvatar: author avatar
- case:
features
- description: Used to configure the feature list of home page
- frontmatter options:
- title:标题
- details:详情
- case:
footer
- description: Used to configure the
Footer
module - frontmatter options:
- record: Domain name filing copy
- recordLink: Domain name registration address
- cyberSecurityRecord: Police record copy
- cyberSecurityLink: Public security record address
- startYear: Start time of this site
- case:
MdContent
- description: The markdown text display module of the home page
- case: -
Comment
- description: Comment function, if the site wants to put the comment function on the home page, you can configure this option
- case: -
Case
---
home: true
modules: # Designated homepage display module - BannerBrand
- Blog
- MdContent
- Features
- Footer
banner: # banner module configuration
heroText: 午后南杂
tagline: Enjoy when you can, and endure when you must.
heroImage: /logo.png
heroImageStyle:
maxWidth: 200px
margin: 0 auto 2rem
bgImage: /banner.jpg
bgImageStyle:
height: 450px
bannerBrand: # bannerBrand module configuration
title: vuepress-reco
description: A simple vuepress Blog & Doc theme.
tagline: vuepress-theme-reco 2.0 continues to adhere to the concise style, all functions are out of the box, the home page is assembled modularly, the style is written with tailwindcss, and Vite is used as the default compiler. You only need to be responsible for content creation, please leave the rest to me.
bgImage: /banner.jpg
bgImageStyle:
height: 450px
buttons:
- { text: Guide, link: '/docs/guide/introduce' }
- { text: Default Style, link: '/docs/theme/introduce', type: 'plain' }
socialLinks: # For social address
- { icon: 'LogoGithub', link: 'https://github.com/recoluan' }
blog: # blog module configuration
socialLinks: # For social address
- { icon: 'LogoGithub', link: 'https://github.com/recoluan' }
features:
- title: Past
details: Develop a vuepress blog theme that looks happy and writes smoothly.
- title: Present
details: Help more friends save time to write content with heart, instead of just configuring a blog to enjoy yourself.
- title: Future
details: Attract more friends to participate in the development and continue to have powerful functions.
footer: # footer module configuration
record: Domain name filing copy
recordLink: Domain name registration address
cyberSecurityRecord: Police record copy
cyberSecurityLink: Public security record address
startYear: 2018
---
Custom Home Module
WARNING
The css scheme of the reco theme is postcss + tailwindcss, which supports the latest CSS nesting proposal (class scss), you need to pay attention when writing styles for components.
As long as the component is registered globally, it can be used by the home page as a module of the home page.
First, you can refer to Register Components to register the homepage module component as a global component, and then configure it in the frontmatter of the homepage (if the custom module component is CustomModule):
---
home: true
modules: # Designated homepage display module
- CustomModule
- Footer
customModule: # customModule module configuration
key: value
footer: # footer module configuration
record: Domain name filing copy
recordLink: Domain name registration address
cyberSecurityRecord: Police record copy
cyberSecurityLink: Public security record address
startYear: 2018
---
When developing the front page module, you can get the frontmatter
configuration by the following methods:
import { usePageFrontmatter, withBase } from 'vuepress/utils'
const frontmatter = usePageFrontmatter()