Deploying
The following guides are based on some shared assumptions:
- You are placing your docs inside the
docs
directory of your project; - You are using the default build output location (
.vuepress/dist
); - VuePress is installed as a local dependency in your project, and you have setup the following npm scripts:
{
"scripts": {
"docs:build": "vuepress build docs"
}
}
GitHub Pages
Set correct
base
indocs/.vuepress/config.js
.If you are deploying to
https://<USERNAME>.github.io/
, you can omitbase
as it defaults to"/"
.If you are deploying to
https://<USERNAME>.github.io/<REPO>/
, (that is your repository is athttps://github.com/<USERNAME>/<REPO>
), setbase
to"/<REPO>/"
.Inside your project, create
deploy.sh
with the following content (with highlighted lines uncommented appropriately) and run it to deploy:
#!/usr/bin/env sh
# abort on errors
set -e
# build
npm run docs:build
# navigate into the build output directory
cd docs/.vuepress/dist
# if you are deploying to a custom domain
# echo 'www.example.com' > CNAME
git init
git add -A
git commit -m 'deploy'
# if you are deploying to https://<USERNAME>.github.io
# git push -f git@github.com:<USERNAME>/<USERNAME>.github.io.git master
# if you are deploying to https://<USERNAME>.github.io/<REPO>
# git push -f git@github.com:<USERNAME>/<REPO>.git master:gh-pages
cd -
You can also run the above script in your CI setup to enable automatic deployment on each push.
GitHub Pages and Travis CI
Set correct
base
indocs/.vuepress/config.js
.If you are deploying to
https://<USERNAME or GROUP>.github.io/
, you can omitbase
as it defaults to"/"
.If you are deploying to
https://<USERNAME or GROUP>.github.io/<REPO>/
, (that is your repository is athttps://github.com/<USERNAME>/<REPO>
), setbase
to"/<REPO>/"
.Create a file named
.travis.yml
in the root of your project.Run
npm install
locally and commitpackage-lock.json
as it’s required fornpm ci
.Use GitHub Pages deploy provider template and follow the travis documentation.
language: node_js
node_js:
- lts/*
install:
- npm ci
script:
- npm run docs:build
deploy:
provider: pages
skip-cleanup: true
local_dir: docs/.vuepress/dist
github-token: $GITHUB_TOKEN # a token generated on github allowing travis to push code on you repository
keep-history: true
on:
branch: master
GitLab Pages and GitLab CI
Set correct
base
indocs/.vuepress/config.js
.If you are deploying to
https://<USERNAME or GROUP>.gitlab.io/
, you can omitbase
as it defaults to"/"
.If you are deploying to
https://<USERNAME or GROUP>.gitlab.io/<REPO>/
, (that is your repository is athttps://gitlab.com/<USERNAME>/<REPO>
), setbase
to"/<REPO>/"
.Set
dest
in.vuepress/config.js
topublic
.Create a file called
.gitlab-ci.yml
in the root of your project with the content below. This will build and deploy your site whenever you make changes to your content.
image: node:9.11.1
pages:
cache:
paths:
- node_modules/
script:
- npm install
- npm run docs:build
artifacts:
paths:
- public
only:
- master
Netlify
- On Netlify, setup up a new project from GitHub with the following settings:
- Build Command:
npm run docs:build
oryarn docs:build
- Publish directory:
docs/.vuepress/dist
- Hit the deploy button!
Google Firebase
Make sure you have firebase-tools installed.
Create
firebase.json
and.firebaserc
at the root of your project with the following content:
firebase.json
:
{
"hosting": {
"public": "./docs/.vuepress/dist",
"ignore": []
}
}
.firebaserc
:
{
"projects": {
"default": "<YOUR_FIREBASE_ID>"
}
}
- After running
yarn docs:build
ornpm run docs:build
, deploy with the commandfirebase deploy
.
Surge
First install surge, if you haven’t already.
Run
yarn docs:build
ornpm run docs:build
.Deploy to surge, by typing
surge docs/.vuepress/dist
.
You can also deploy to a custom domain by adding surge docs/.vuepress/dist yourdomain.com
.
Heroku
First install Heroku CLI.
Create a Heroku account here.
Run
heroku login
and fill in your Heroku credentials:heroku login
Create a file called
static.json
in the root of your project with the content below:static.json
:{ "root": "./docs/.vuepress/dist" }
This is the configuration of your site. See more at heroku-buildpack-static.
- Set up your Heroku git remote:
# version change
git init
git add .
git commit -m "My site ready for deployment."
# creates a new app with a specified name
heroku apps:create example
# set buildpack for static sites
heroku buildpacks:set https://github.com/heroku/heroku-buildpack-static.git
- Deploying Your Site
# publish site
git push heroku master
# opens a browser to view the Dashboard version of Heroku CI
heroku open
Now
Please check out Deploy an example VuePress site with Now.