VuePress 静态网站生成方法步骤


Posted in Javascript onFebruary 14, 2019

使用技术:

VuePress - Vue 驱动的静态网站生成器

仓库地址:https://github.com/yinian-R/vuepress-demo

全局安装

## 安装
yarn global add vuepress # 或者:npm install -g vuepress

现有项目

如果你想在一个现有项目中使用 VuePress,同时想要在该项目中管理文档,则应该将 VuePress 安装为本地依赖。

## 没有项目可以初始化
yarn init

## 将 VuePress 作为一个本地依赖安装
yarn add -D vuepress # 或者:npm install -D vuepress

## 新建一个 docs 文件夹
mkdir docs

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

## 开始写作
npx vuepress dev docs

接着,在 package.json 里加一些脚本:

{
 "scripts": {
  "docs:dev": "vuepress dev docs",
  "docs:build": "vuepress build docs"
 }
}

基本配置

.
├─ docs
│ ├─ README.md
│ └─ .vuepress
│   └─ config.js

一个 VuePress 网站必要的配置文件是 .vuepress/config.js,它应该导出一个 JavaScript 对象:

module.exports = {
 title: 'Hello VuePress',
 description: 'Just playing around'
}

静态资源

创建public文件夹,主要用于存放静态资源

.
├─ docs
│ └─ .vuepress
│   └─ public
│     └─ image
│        └─ favicon.ico

添加网站 favicon,修改 .vuepress/config.js 内容

module.exports = {
  head:[
    ['link', {rel:'icon', href:'/image/favicon.ico'}]
  ]
};

导航栏

你可以通过 themeConfig.nav 增加一些导航栏链接:

module.exports = {
  themeConfig: {
    nav: [
      { text: '主页', link: '/' },
      { text: '指南', link: '/guide/' },
      {
        text: '语言',
        items: [
          { text: '中文', link: '/language/chinese/' },
          { text: 'English', link: '/language/english/' }
        ]
      },
      { text: 'GitHub', link: 'https://github.com' }
    ]
  }
};

首页

需要在dosc/README.md指定 home: true

---
home: true
heroImage: /image/favicon.ico
heroText: Hero 标题
tagline: Hero 副标题
actionText: 快速上手 →
actionLink: /guide/
features:
- title: 简洁至上
 details: 以 Markdown 为中心的项目结构,以最少的配置帮助你专注于写作。
- title: Vue驱动
 details: 享受 Vue + webpack 的开发体验,在 Markdown 中使用 Vue 组件,同时可以使用 Vue 来开发自定义主题。
- title: 高性能
 details: VuePress 为每个页面预渲染生成静态的 HTML,同时在页面被加载的时候,将作为 SPA 运行。
footer: MIT Licensed | Copyright © 2018-present Evan You
---

侧边栏

想要使 侧边栏(Sidebar)生效,需要配置 themeConfig.sidebar,基本的配置,需要一个包含了多个链接的数组:

module.exports = {
  themeConfig: {
    sidebar: [
      '/',
      ['/hello', 'hello page']
    ]
  }
};

部署

设置部署站点的基础路径。

module.exports = {

  base: '/vuepress-demo/',
  
};

在你的项目中,创建一个如下的 deploy.sh 文件

#!/usr/bin/env bash
# 确保脚本抛出遇到的错误
set -e

# 生成静态文件
npm run docs:build

# 进入生成的文件夹
cd docs/.vuepress/dist

# 如果是发布到自定义域名
# echo 'www.example.com' > CNAME

git init
git add -A
git commit -m 'deploy'

# 如果发布到 https://<USERNAME>.github.io
# git push -f git@github.com:<USERNAME>/<USERNAME>.github.io.git master

# 如果发布到 https://<USERNAME>.github.io/<REPO>
 git push -f git@github.com:yinian-R/vuepress-demo.git master:gh-pages

cd -

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
Javascript 网页水印(非图片水印)实现代码
Mar 01 Javascript
javascript上传图片前预览图片兼容大多数浏览器
Oct 25 Javascript
探寻Javascript执行效率问题
Nov 12 Javascript
在Python中使用glob模块查找文件路径的方法
Jun 17 Javascript
详解Webwork中Action 调用的方法
Feb 02 Javascript
angular+webpack2实战例子
May 23 Javascript
详解Angular-cli生成组件修改css成less或sass的实例
Jul 27 Javascript
Nuxt.js实现校验访问浏览器类型的中间件
Aug 24 Javascript
JavaScript惰性求值的一种实现方法示例
Jan 11 Javascript
详解Node.js使用token进行认证的简单示例
May 25 Javascript
详解JavaScript 高阶函数
Sep 14 Javascript
了不起的11个JavaScript代码重构最佳实践小结
Jan 11 Javascript
extract-text-webpack-plugin用法详解
Feb 14 #Javascript
JavaScript&quot;模拟事件&quot;的注意要点详解
Feb 13 #Javascript
快速了解Node中的Stream流是什么
Feb 13 #Javascript
vue2.0+vue-router构建一个简单的列表页的示例代码
Feb 13 #Javascript
vue实现点击隐藏与显示实例分享
Feb 13 #Javascript
JS+canvas画布实现炫酷的旋转星空效果示例
Feb 13 #Javascript
JavaScript实现的拼图算法分析
Feb 13 #Javascript
You might like
php 网上商城促销设计实例代码
2012/02/17 PHP
解析PHP对现有搜索引擎的调用
2013/06/25 PHP
关于Laravel Route重定向的一个注意点
2017/01/16 PHP
在Javascript中为String对象添加trim,ltrim,rtrim方法
2006/09/22 Javascript
了解jQuery技巧来提高你的代码
2010/01/08 Javascript
基于JQuery实现鼠标点击文本框显示隐藏提示文本
2012/02/23 Javascript
js和jquery中循环的退出和继续下一个循环
2014/09/03 Javascript
兼容各大浏览器的JavaScript阻止事件冒泡代码
2015/07/09 Javascript
C++中的string类的用法小结
2015/08/07 Javascript
JavaScript判断表单中多选框checkbox选中个数的方法
2015/08/17 Javascript
JS排序方法(sort,bubble,select,insert)代码汇总
2016/01/30 Javascript
JS实现动态表格的添加,修改,删除功能(推荐)
2016/06/15 Javascript
jquery 点击元素后,滚动条滚动至该元素位置的方法
2016/08/05 Javascript
微信小程序  生命周期详解
2016/10/27 Javascript
利用js+css+html实现固定table的列头不动
2016/12/08 Javascript
Vue 仿百度搜索功能实现代码
2017/02/16 Javascript
限时抢购-倒计时的完整实例(分享)
2017/09/17 Javascript
JavaScript单线程和任务队列原理解析
2020/02/04 Javascript
vue下canvas裁剪图片实例讲解
2020/04/16 Javascript
React实现评论的添加和删除
2020/10/20 Javascript
Python自定义函数实现求两个数最大公约数、最小公倍数示例
2018/05/21 Python
Pycharm 操作Django Model的简单运用方法
2018/05/23 Python
从运行效率与开发效率比较Python和C++
2018/12/14 Python
利用pyecharts实现地图可视化的例子
2019/08/12 Python
Python一键查找iOS项目中未使用的图片、音频、视频资源
2019/08/12 Python
关于python3中setup.py小概念解析
2019/08/22 Python
Python3使用xlrd、xlwt处理Excel方法数据
2020/02/28 Python
python使用paramiko实现ssh的功能详解
2020/03/06 Python
Python调用REST API接口的几种方式汇总
2020/10/19 Python
python如何发送带有附件、正文为HTML的邮件
2021/02/27 Python
COACH德国官方网站:纽约现代奢侈品牌,1941年
2018/06/09 全球购物
IT工程师岗位职责
2014/07/04 职场文书
违反工作规定检讨书范文
2014/12/14 职场文书
优秀党员先进事迹材料
2014/12/18 职场文书
2016银行招聘自荐信
2016/01/28 职场文书
pytorch 如何把图像数据集进行划分成train,test和val
2021/05/31 Python