Vuepress 搭建带评论功能静态博客代码实现,详细有学习价值

2019-02-1717:27:45网站建设与开发Comments3,070 views字数 2927阅读模式
Vuepress 搭建带评论功能的静态博客的实现,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

vuepress 是 Vue 驱动的静态站点生成工具文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

本文仅介绍,搭建静态博客的过程,具体教程及文档请点击进入 vuepress中文网文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

点击查看项目代码文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

vuepress初始化文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

下面初始化文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

# 将 github 新创建的仓库克隆到本地
git clone git@github.com:zhb333/readme-blog.git

# 进入项目
cd readme-blog

# npm 初始化, 按照提示回车
npm init

# 安装 vuepress
npm i vuepress -D

# 安装 gh-pages
npm i gh-pages -D

# 创建一个 docs 目录
mkdir docs

# 创建一个 markdown 文件
echo '# Hello VuePress' > docs/README.md

npm 脚本文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

然后,给 package.json 添加一些 scripts 脚本:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

{
 "scripts": {
  "dev": "vuepress dev docs",
  "build": "vuepress build docs",
  "deploy": "npm run build && gh-pages -d docs/.vuepress/dist"
 }
}

运行本地开发环境文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

运行 vurepress 的本地开发环境文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

npm run dev

访问 localhost:8080 , 已经成功开启文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

基础配置文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

生成静态资源文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

执行下面的命令,生成静态资源文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

npm run build

默认情况下,构建的文件会位于 docs/.vuepress/dist 中,该文件可以通过 docs/.vuepress/config.js 中的 dest 字段进行配置。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

配置文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

创建 docs/.vuepress/config.js, 并进行简单配置文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

var config = {

 // 静态网站部署的目录
 base: '/readme-blog/',

 // 网站标题
 title: '标 の 博客',

 // <meta name="description" content="...">
 description: '种一棵树最好的时间是十年前,其次是现在', 

 markdown: {
  
  // 显示代码行号
  lineNumbers: true
 }
}

module.exports = config

博客首页文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

公共文件文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

创建 docs/.vuepress/public 用于存放公共文件文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

我在 public/ , 存在了 favicon.ico 图标, 以及 zlx.jpg 首页的头像图片文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

简单的首页编写文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

将 docs/README.md设置为首页, 修改代码为:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

---
home: true
heroImage: /zlx.jpg
footer: MIT Licensed | Copyright © 2018 ZhangHuanbiao
---

设置网站 ico 图标文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

配置网站的 ico 图标, 修改 .vuepress/config.js:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

const config = {
 head: [
  ['link', { rel: 'icon', href: '/favicon.ico' }]
 ]
}

导航栏文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

配置导航栏文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

使用 vuepress 的默认主题配置导航栏 .vuepress/config.js:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

const nav = [
 {
  text: '前端栈',
  items: [
   { text: 'Vue', link: '/WEB/Vue/vuepress-blog' },
   { text: 'React', link: '/WEB/React/react-router' }
  ]
 }
]

const config = {
 themeConfig: {

  // 项目的 github 地址
  repo: 'zhb333/readme-blog',

  // github 地址的链接名
  repoLabel: '代码',

  // 配置导航栏
  nav,
 },
}

创建有效的导航资源文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

为了使得导航栏的链接点击有效, 我们创建两个文件:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

docs/WEB/Vue/vuepress-blog.md文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

# 使用`vuepress`搭建静态博客
## vuepress初始化
## 基础配置
## 博客首页
## 导航栏

docs/WEB/React/react-router.md文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

# react-router

侧边栏文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

侧边栏配置文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

使用 vuepress 的默认主题配置侧边栏 .vuepress/config.js:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

const sidebar = {
 '/WEB/': [
  {
   title: 'Vue',
   children: [
    'Vue/vuepress-blog'
   ]
  },

  {
   title: 'React',
   children: [
    'React/react-router'
   ]
  }
 ]
}

const nav = [
 {
  text: '前端栈',
  items: [
   { text: 'Vue', link: '/WEB/' + sidebar['/WEB/'][0]['children'][0] },
   { text: 'React', link: '/WEB/' + sidebar['/WEB/'][1]['children'][0] }
  ]
 }
]

var config = {
 themeConfig: {

  // 当前 markdown 的 github 代码链接
  editLinks: true,

  // 链接显示的文本
  editLinkText: '查看原文|编辑此页',

  nav,
  sidebar,
 },
}

侧边栏效果文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

访问: http://localhost:8080/readme-blog/WEB/Vue/vuepress-blog.html, 可以看到侧边栏已经生成文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

将静态博客网站部署到外网文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

使用 gh-pages 进行项目部署文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

npm run deploy

过几分钟后,访问 https://zhb333.github.io/readme-blog/, 便可以看到在外网成功部署的静态博客文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

评论功能文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

我们使用 valine 来实现评论功能:文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

Valine - 一款快速、简洁且高效的无后端评论系统。文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

点击进入 Valine官网 ,需要先注册才能食用文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

安装 Valine文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

# Install leancloud's js-sdk
npm install leancloud-storage --save

# Install valine
npm install valine --save

注册 vuepress 全局组件文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

创建 .vuepress/components/Valine.vue文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

<template>
 <div id="vcomments"></div>
</template>

<script>
export default {
 name: 'Valine',
 mounted: function(){
  // require window 
  const Valine = require('valine');
  if (typeof window !== 'undefined') {
   this.window = window
   window.AV = require('leancloud-storage')
   
  }
   
  new Valine({
   el: '#vcomments' ,
   appId: '',// your appId
   appKey: '', // your appKey
   notify:false, 
   verify:false, 
   avatar:'mm', 
   placeholder: 'just go go' 
  });
 },
}
</script>

使用 Valine文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

只需要在 markdown 中调用即可文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html

<Valine></Valine>
文章源自菜鸟学院-https://www.cainiaoxueyuan.com/cms/9618.html
  • 本站内容整理自互联网,仅提供信息存储空间服务,以方便学习之用。如对文章、图片、字体等版权有疑问,请在下方留言,管理员看到后,将第一时间进行处理。
  • 转载请务必保留本文链接:https://www.cainiaoxueyuan.com/cms/9618.html

Comment

匿名网友 填写信息

:?: :razz: :sad: :evil: :!: :smile: :oops: :grin: :eek: :shock: :???: :cool: :lol: :mad: :twisted: :roll: :wink: :idea: :arrow: :neutral: :cry: :mrgreen:

确定