Skip to content
A vuejs and nodejs project 🇨🇳
JavaScript CSS Vue HTML
Branch: master
Clone or download
Pull request Compare This branch is 144 commits behind wmui:master.
Fetching latest commit…
Cannot retrieve the latest commit at this time.
Permalink
Type Name Latest commit message Commit time
Failed to load latest commit information.
build
example/demo
public
server
src
static
.babelrc
.eslintignore
.eslintrc.js
.gitignore
.travis.yml
LICENSE
README.md
ecosystem.json
manifest.json
package-lock.json
package.json
server.js

README.md

Build Status Version License

预览

如果演示网址无法访问,应该是阿里云的香港区服务器在搞事情,实在抱歉。

版本更新

v1.0.1 前端模板使用css3 flexbox进行了重构,类的命名规范化,后台样式微调整
v1.1.0 添加管理员在前台可编辑和删除文章功能,token验证进行深度加密
v1.1.1 添加评论组件
v1.1.2 添加eslint语法检测工具
关闭eslint方法: 打开build/webpack.base.config.js,注销掉29-37行的代码即可

最新计划

  • 添加eslint语法检测工具
  • 增加单元测试
  • 文章上传图片功能
  • 手机端模板调整(APP标准)

开发环境和技术栈

  • 操作系统:windows10 64位
  • 开发工具 :webstorm sublime
  • 前端:Vue + vue-router + vuex
  • 后端:Node.js(采用express框架) + mongodb

特色功能

  • 支持服务端渲染
  • 支持标题动态切换
  • 支持PWA
  • 支持markdown语法,样式采用github风格,代码高亮
  • 支持文章保存为草稿
  • 支持标签和归档功能

目录结构

    ┌─ build                          // 配置文件
    ├─ example                        // 演示
    ├─ public                         // 公共资源
    ├─ server                         // 服务端
    │      ├─ db.js                   // 数据库dao层封装
    │      ├─ md5.js                  // 密码加密
    │      ├─ router.js               // 服务端路由
    │      └─ settings.js             // 数据库初始化配置
    ├─src                             // 前端
    │   ├─ api                        // 所有的api请求
    │   ├─ assets                     // 前端模板
    │   ├─ components                 // vue组件
    │   │          ├─ admin           // 后台可复用组件
    │   │          └─ global          // 前端可复用组件
    │   ├─ router                     // 前端路由
    │   ├─ store                      // vuex文件
    │   ├─ util                       // 公共函数库
    │   │    ├─ filters.js            // 过滤器函数
    │   │    └─ title.js              // 标题函数
    │   ├─ views                      // 组件库
    │   │    ├─ admin                 // 后台组件
    │   │    ├─ Article.vue           // 文章详情页
    │   │    ├─ CreateListView.js     // 预渲染
    │   │    ├─ List.Vue              // 文章列表
    │   │    └─ Login.Vue             // 登陆
    │   ├─ app.js                     // 项目入口文件
    │   ├─ App.vue                    // 全局组件
    │   ├─ entry-client.js            // 客户端渲染
    │   ├─ entry-server.js            // 服务端渲染
    │   └─ index.template.html        // 模板
    ├─ static                         // 静态文件
    ├─ .babelrc                       // babel配置
    ├─ .gitignore                     // git上传忽略
    ├─ ecosystem.json                 // pm2配置
    ├─ manifest.json                  // PWA配置
    ├─ LICENSE                        // 开源协议
    ├─ package.json                   // npm包管理
    ├─ README.md                      // 项目说明
    ├─ server.js                      // 项目启动文件
    └─ yarn.lock                      // yarn配置

pc端效果图

首页效果图

image

代码高亮效果图

image

后台发布页面

image

后台文章列表

image

修改个人信息

image

手机端效果图,以chrome浏览器演示

添加到主屏

image

文章页效果

image

Lighthouse测试

image

本地运行项目

  1. 安装mongodb并启动
  2. 安装nodejs环境
  3. 修改/server/settings.js下的配置项信息,你也可以默认不修改,默认用户名:q,默认密码:q
    let user = 'q';
    let pass = md5('q');
    let avatar = 'avatar.jpg';
    let intro ='Never too old to learn';
    let nickname = 'VueBlog';
    module.exports = {
        dbUrl:'mongodb://localhost:27017/vueblog',
        user:user,
        pass:pass,
        avatar:avatar,
        intro:intro,
        nickname:nickname
    }
  1. 打开本地终端,执行npm install,npm run dev ,访问http://localhost:8080

结语

本项目基于vue-hackernews-2.0开发,长期更新,由于是个人项目,不建议直接用于线上,欢迎issue,欢迎PR,该项目不会添加过多复杂功能,追求轻量,以原生APP的体验作为目标。

开源协议

GPL-3.0

You can’t perform that action at this time.