a blog platform built with vue, koa and mongo. 使用vue,koa和mongo搭建的博客页面和markdown语法的博客编写平台,自动保存草稿。
博客预览地址:http://chuckliu.me
kov-blog
使用了vue
、vuex
、koa
和mongo
等框架和技术。前后端分离,restful架构。项目主要包含三个文件夹和项目:
- server 后台 包含了所有的后台服务,为博客和博客管理提供后台接口
- client 前端 博客的前端呈现,被
vue
洗脑严重,界面模仿了vue官方博客,评论系统用的是多说(但是多说很不稳定...而且已经很久无人维护..) - admin 前端 博客管理平台的前端,功能上类似于带发布博客功能的印象笔记,markdown语法,预览和编写同步进行,带有自动保存功能,书写的文章只有在
发布
之后才会同步当前内容到博客client页面上,也完全可以当做一个笔记类应用去用,这样做的目的是出于有的时候在写文章a的时候,觉得某一部分的内容过于复杂,可以另外开一篇文章b来仔细讲解下,但是等我写完a就忘了,因为以往的博客cms比如hexo,wordpress之类都是直接发布的.而且这样做了之后博客也好用多了,我经常在码代码的时候遇到一些问题,这样可以直接打开博客后台,开一篇文章记录一下遇到的问题,但是不发布出去,提醒自己需要整理一篇相关内容的文章.以后一登这个管理系统就可以看到了这篇没有没有发布过的文章,就可以整理这篇文章,等到写完之后发布出去就可以了.
使用了许多es6新特性,请使用6.0以上版本的node!
使用之前请先确保已经安装mongo!
如果要使用评论系统,请先注册多说,修改/client/src/Blog.vue中的多说二级域名为您自己的多说二级域名
基于restful,nodejs的话采用koa框架(koa 1),数据库用了mongo。登录这块的话用了jwt.
生产环境下可在可在server/configs目录下增加private.js文件,增加私有配置.
因为使用了许多es6/7 新语法,所以请使用6.x版本node
使用windows的同学在npm run dev-server之前请看下面的npm command的说明哈.
# install dependencies
npm install
# 开发
# 带热重载,跑在本地3000端口
# npm run dev-server在mac/linux下run起来没问题,但是NODE_ENV=development DEBUG=kov-blog这样的语法在windows上的cmd上面是不行的
# 所以使用windows的cmd的同学请不要使用npm run dev-server 而是输入下面这行命令吧
# set NODE_ENV=production && set DEBUG=kov-blog && supervisor --harmony server/index.js
npm run dev-server
# 部署
npm run build-server
博客呈现页面,基于vue(1.0),前后端通信用的fetch,评论系统用的是多说,界面模仿了vue博客,大量使用了其样式效果,还有很多要完善的地方。
# install dependencies
npm install
# 开发,跑在本地8080端口
npm run dev-client
# 打包
npm run build-client
初始用户名:admin,初始密码:password
博客管理系统,也是前后端完全分离的。功能上类似于印象笔记,实时保存你的文章,当你觉得写好了之后可以发布
文章,每次发布
都会把文章同步更新到博客上,这样在client端就能看到。采用markdown语法,编辑器采用的是SimpleMDE,支持大量快捷键。
快捷键 | Action |
---|---|
Cmd-' | "toggleBlockquote" |
Cmd-B | "toggleBold" |
Cmd-E | "cleanBlock" |
Cmd-H | "toggleHeadingSmaller" |
Cmd-I | "toggleItalic" |
Cmd-K | "drawLink" |
Cmd-L | "toggleUnorderedList" |
Cmd-P | "togglePreview" |
Cmd-Alt-C | "toggleCodeBlock" |
Cmd-Alt-I | "drawImage" |
Cmd-Alt-L | "toggleOrderedList" |
Shift-Cmd-H | "toggleHeadingBigger" |
F9 | "toggleSideBySide" |
F11 | "toggleFullScreen" |
# install dependencies
npm install
# 开发,跑在本地8081端口
npm run dev-admin
# 打包
npm run build-admin