vue2+express+mongoose后台管理系统

Vue-admin

这是一个不简单的全栈后台管理系统。

想法

做一个全栈项目,可以发表文章,管理评论、用户、标签、文章、添加图片等类似于wordpress的项目,主要是学习mongoose操作mongodb数据库,学习一对多,多对多关系设计。

由于工作量很大,将后期陆续完成。

主要功能有:

  1. 首页 (一些文章新增,用户动态)
  2. 文章管理(文章列表+新增文章)
  3. 菜单管理(分配菜单)
  4. 角色管理(暂时只有两种用户:管理员+一般用户)
  5. 页面管理(后期新增一些模板,可以新增菜单链接相应页面)
  6. 文章标签管理
  7. 文章分类管理
  8. 用户管理

技术栈

  • [ ] vue2
  • [ ] vuex
  • [ ] axios
  • [ ] vue-router
  • [ ] express
  • [ ] mongoose
  • [ ] iview
  • [ ] vue-echarts

效果

下载&安装

git clone https://github.com/shawn2016/vue-admin.git
cd vue-admin
npm i
复制代码

运行

npm start
复制代码

后台服务

先启动mongodb服务:https://www.cnblogs.com/wzlblog/p/6364045.html)

npm run server
复制代码

目录说明

.

├── README.md
├── app.js #启动文件
├── beizhu.md #字段说明
├── build #vue-cli
│   ├── build.js
│   ├── check-versions.js
│   ├── logo.png
│   ├── utils.js
│   ├── vue-loader.conf.js
│   ├── webpack.base.conf.js
│   ├── webpack.dev.conf.js
│   └── webpack.prod.conf.js
├── config
│   ├── db.js #mogodb地址
│   ├── dev.env.js
│   ├── index.js
│   ├── prod.env.js
│   └── test.env.js
├── index.html
├── package.json
├── router
│   └── index.js #路由分发
├── server #后台服务层
│   ├── DBhelper #公共sql方法
│   │   └── dbHelper.js
│   ├── DBsql #模型sql操作
│   │   ├── articleDao.js
│   │   ├── homeDao.js
│   │   ├── menuDao.js
│   │   ├── pageDao.js
│   │   ├── roleDao.js
│   │   └── userDao.js
│   ├── controller #mvc中C层,做逻辑处理
│   │   ├── articleManagementController.js
│   │   ├── homeManagementController.js
│   │   ├── menuManagementController.js
│   │   ├── pageManagementController.js
│   │   ├── roleManagementController.js
│   │   └── userManagementController.js
│   ├── models # mvc中m层,数据表模型
│   │   ├── article.js
│   │   ├── home.js
│   │   ├── menu.js
│   │   ├── page.js
│   │   ├── role.js
│   │   └── user.js
│   └── utils
│       ├── filterData.js # 返回格式处理
├── src #前台
│   ├── App.vue
│   ├── assets
│   │   └── styles
│   ├── components #公用组件
│   │   ├── breadcrumb.vue #面包屑
│   │   ├── bus.js #加载条
│   │   ├── editor.vue #富文本编辑器
│   │   ├── layout.vue #布局
│   │   └── navcontent.vue #导航条
│   ├── config
│   │   ├── env.js
│   │   ├── index.js
│   │   └── mUtils.js
│   ├── data # mock数据
│   │   ├── bar.js
│   │   ├── connect.js
│   │   ├── logo.js
│   │   ├── map.js
│   │   ├── pie.js
│   │   ├── polar.js
│   │   ├── scatter.js
│   │   └── theme.json
│   ├── favicon.ico
│   ├── filters #过滤器
│   │   ├── commonFilter.js
│   │   ├── date.js
│   │   └── index.js
│   ├── langs #富文本编辑器中文
│   │   └── zh_CN.js
│   ├── libs #请求方法与配置
│   │   ├── baseUrl.js
│   │   ├── fetch.js
│   │   ├── tree
│   │   └── util.js
│   ├── main.js
│   ├── pages #所有页面
│   │   ├── articleManage #文章管理
│   │   ├── home #首页
│   │   ├── login # 登陆 注册 重置密码
│   │   ├── menuManage #菜单管理
│   │   ├── pageManage #页面管理
│   │   ├── roleManage #角色管理
│   │   └── userManage #用户管理
│   ├── router #vue路由
│   │   └── index.js
│   ├── service #所有请求由这里发出
│   │   ├── getData.js
│   │   └── randomWord.js
│   ├── skins #富文本编辑器
│   │   └── lightgray
│   └── store #vuex
│       ├── action.js
│       ├── getters.js
│       ├── index.js
│       ├── mutation-types.js
│       └── mutations.js
├── static #静态资源
│   ├── addArticle.png
│   ├── article.png
│   ├── dashboard.png
│   └── updateArtilce.png
├── test 
    └── unit
        ├── jest.conf.js
        ├── setup.js
        └── specs

复制代码

tree 目录生成命令

tree -L 3 -I "node_modules"

brew install tree  ||  apt-get install tree

- tree -d 只显示文件夹;
- tree -L n 显示项目的层级。n表示层级数。比如想要显示项目三层结构,可以用tree -l 3;
- tree -I pattern 用于过滤不想要显示的文件或者文件夹。比如你想要过滤项目中的node_modules文件夹,可以使用tree -I "node_modules";
- tree > tree.md 将项目结构输出到tree.md这个文件。

复制代码

License

Licensed under the MIT License.

这个系统其实是出于学习nodejs的目的而改写的系统。 原来的系统前端使用了extjs4.2.1,后端使用了PHP5.4和ZEND框架开发,后台数据库是用mongodb2.2.2。 我抽离出了原来系统中的账户管理,角色管理,菜单管理,权限管理这4个部分, 我想这4个部分,基本上所有的系统都会用到。具有一定的普遍性。所以将这4个部分用nodejs重新改写了。 该系统目前使用模块有express,ejs,connect-mongo,mongodb,express-partials,connect-flash,fibers,wind等 其实wind模块这次系统中没有使用。可以将它排除出去。我是出于学习wind的目的,才加入这个模块的。 本来准备使用wind模块,是为了实现同步的目的,由于后来改用了fibers模块之后,就没有使用它。这里说明一下 不是fibers要比wind好,而是我暂时不能理解wind,或则是说对wind的研究不够吧。 众所周知nodejs是推崇异步模式。但是这个系统是从php过来的,而php的代码是同步模式的写法,所以为了在改写的过程中 希望 1是代码改动最少 2是同步写法更加适合思维习惯。而且代码可读性高的目的,用到了fibers。 这个系统的源代码中有些js文件里保留了一些原来的PHP代码,这是出于代码对比的目的。 是让大家了解原来的php代码是怎么实现的,用nodejs之后是如何改写的。通过对比,大家会发现 其实通过使用fibers之后,几乎两者是一模一样的。 还有源代码中还保留了一些被注释掉的函数,有些是用到了wind,有些是用到了fibers,有些是直接异步的写法。 这些内容都是在开发过程中我不断尝试后的产物。我花了1周的时间才实现了一个递归的调用,而且还是同步的方式。 到目前为止,我还不能理解在异步模式下实现递归调用函数。比如说源代码中有个函数getMenuTree,菜单下面可能有子菜单, 子菜单的下面可能还有菜单。所以是一个递归的过程。我现在是同步的写法实现了这个函数,如果有人能够提供异步写法实现的递归函数并 emai给我,我不胜荣幸。 在使用本系统之前,必须要安装nodejs 0.10.10,mongodb2.2.2,python2.7.5至于安装的方法请googel解决。 将源代码下载之后,解压到某个目录下,比如说d:\nodejs\umav4simple目录。 进入到那个目录, a)运行以下命令 npm install express npm install ejs npm install connect-mongo npm install mongodb npm install express-partials npm install connect-flash npm install fibers npm install wind 尽管在源代码中已包含了这些模块,但是最好还是要重新运行一遍。 因为有些模块可能需要重新的编译。 比如说fibers模块,我在window下运行npm install fibers的时候编译了一个win32-ia32-v8-3.14 而在linux下重新编译了linux-ia32-v8-3.14。所以说根据操作系统的不同,可能会有一些不同。 以免造成想不到的错误。 b)打开settings.js,并且将你的mongodb的设置改写并保存。 c)运行node app.js或则node cluster.js 如果没有提示错误的话,那么就说明环境配置成功了。 d)通过以下的URL可以在mongodb中追加一些数据,不过只能运行一次。否则会重复追加数据。 浏览器上输入 http://localhost:3000/admin/index/install 做完之后, 浏览器上输入http://localhost:3000/ 就通过用户名admin 密码adminadmin进行登录,并使用这个系统了。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值