Home Page

reco_luan2021-11-06 23:36:01

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:BannerBannerBrandFeaturesBlogMdContentCommentFooter
  • 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
  • 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:
    • banner

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:
    • bannerBrand

blog

  • description: Used to configure the Blog module
  • frontmatter options:
    • socialLinks: For social address, See here for settings
      • icon: icon
      • link: button link
  • themeConfig options:
    • author: author name
    • authorAvatar: author avatar
  • case:
    • blog

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:
    • footer

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()
Last Updated 9/6/2024, 2:33:59 PM