forked from AkkomaGang/admin-fe
175 lines
5.8 KiB
Markdown
175 lines
5.8 KiB
Markdown
[data:image/s3,"s3://crabby-images/ffaee/ffaeeb41d9f5f07e5699a9012c043996cba94476" alt="vue"](https://github.com/vuejs/vue)
|
||
[data:image/s3,"s3://crabby-images/8fbe8/8fbe8c7b60e44a4d4c7e5a7e6acb0372d4eb7cee" alt="element-ui"](https://github.com/ElemeFE/element)
|
||
[data:image/s3,"s3://crabby-images/38918/3891815356b76f7e89e03713916de29d4fc4a486" alt="license"](https://github.com/PanJiaChen/vue-element-admin/blob/master/LICENSE)
|
||
[data:image/s3,"s3://crabby-images/2328f/2328f96cb0d5389dcec1c64824563acef63dc6ee" alt="GitHub release"]()
|
||
|
||
## Intro
|
||
|
||
> In the past half year, I have been building a backend for management dashboard using Vue. Though the backend has contained greater than 70 pages and over 10 permissions, it still takes insignificant effort to maintain the project. So I decide to make it open source so as to share my development experience and progress on backend. The tech stack is mainly [Vue.js](https://github.com/vuejs/vue)+[Element](https://github.com/ElemeFE/element)+[axios](https://github.com/mzabriskie/axios). Since it's a personal project, all data requests are simulated with [Mock.js](https://github.com/nuysoft/Mock). **Note:** if anyone wants to modify or develop based on this project, please remove the mock files.
|
||
|
||
**Live demo:** http://panjiachen.github.io/vue-element-admin
|
||
|
||
**Note: element-ui@1.4.2 is used in the project, so vue 2.3.0+ is required.**
|
||
|
||
- vueAdmin-template: [vueAdmin-template](https://github.com/PanJiaChen/vueAdmin-template)
|
||
- electron-vue-admin: [electron-vue-admin](https://github.com/PanJiaChen/electron-vue-admin)
|
||
- Donate:[donate](https://github.com/PanJiaChen/vue-element-admin/blob/master/README-en.md#donate)
|
||
|
||
## Features
|
||
|
||
- Login/Logout
|
||
- Permission authentication
|
||
- Sidebar
|
||
- Breadcrumb
|
||
- Rich text editor
|
||
- Markdown editor
|
||
- JSON editor
|
||
- Drag & drop list
|
||
- SplitPane
|
||
- Dropzone
|
||
- Sticky
|
||
- CountTo
|
||
- ECharts
|
||
- 401, 404 error page
|
||
- Error log
|
||
- Exporting to Excel
|
||
- Upload Excel
|
||
- Table example
|
||
- Interactive table example
|
||
- Drag & drop table example
|
||
- Form example
|
||
- Multi-environments distribution
|
||
- Dashboard
|
||
- Two-factor authentication
|
||
- Collapsing sidebar (support nested routes)
|
||
- Mock data
|
||
- cache tabs example
|
||
- screenfull
|
||
- markdown2html
|
||
- views-tab
|
||
|
||
## Development
|
||
|
||
```bash
|
||
# Clone project
|
||
git clone https://github.com/PanJiaChen/vue-element-admin.git
|
||
|
||
# Install dependencies
|
||
npm install
|
||
|
||
# Or (not recommended for cnpm due to unknown bugs, use taobao mirror instead)
|
||
npm install --registry=https://registry.npm.taobao.org
|
||
|
||
# Run local dev server
|
||
npm run dev
|
||
```
|
||
|
||
Visit in browser: http://localhost:9527
|
||
|
||
## Distribution
|
||
|
||
```bash
|
||
# Build staged environment with webpack-bundle-analyzer
|
||
npm run build:sit-preview
|
||
|
||
# Build production environment
|
||
npm run build:prod
|
||
```
|
||
|
||
## Directory structure
|
||
|
||
```
|
||
├── build // build
|
||
├── config // config
|
||
├── src // source code
|
||
│ ├── api // all requests
|
||
│ ├── assets // static resource like themes, fonts
|
||
│ ├── components // global public components
|
||
│ ├── directive // global directive
|
||
│ ├── filters // global filters
|
||
│ ├── mock // mock data
|
||
│ ├── router // router
|
||
│ ├── store // global status management
|
||
│ ├── styles // global styles
|
||
│ ├── utils // global public functions
|
||
│ ├── view // view
|
||
│ ├── App.vue // entry view
|
||
│ └── main.js // entry for loading components, initialization
|
||
├── static // third-party libraries not packed with Webpack
|
||
│ └── Tinymce // rich text
|
||
├── .babelrc // babel-loader config
|
||
├── eslintrc.js // eslint config
|
||
├── .gitignore // gitignore
|
||
├── favicon.ico // favicon
|
||
├── index.html // html template
|
||
└── package.json // package.json
|
||
```
|
||
|
||
## Changelog
|
||
Detailed changes for each release are documented in the [release notes](https://github.com/PanJiaChen/vue-element-admin/releases).
|
||
|
||
## Donate
|
||
If you find this project useful, you can buy me a cup of coffee
|
||
data:image/s3,"s3://crabby-images/286dc/286dc0c651f4c496ed69b6c7051b8f93aebde100" alt="donate"
|
||
|
||
## State Management
|
||
|
||
Only status of user and app configuration is managed by Vuex. Other data are managed by their own business pages.
|
||
|
||
## Demo
|
||
|
||
#### Two-factor authentication, supporting WeChat and QQ
|
||
|
||
data:image/s3,"s3://crabby-images/cc9d7/cc9d77c5a65397b6baf03b3f95c38beb1af8219b" alt=""
|
||
|
||
#### Realtime switching themes
|
||
|
||
data:image/s3,"s3://crabby-images/5a65d/5a65d0822e802ca6ef3fd130db2317177ed8148b" alt=""
|
||
|
||
#### tabs
|
||
|
||
data:image/s3,"s3://crabby-images/a2e00/a2e0061add367bc136bc249aacea9725228c4c79" alt="tabs"<br />
|
||
|
||
#### Collapsing sidebar
|
||
|
||
data:image/s3,"s3://crabby-images/a937c/a937cd599d29a89147562c0c955b78e75f8393e9" alt=""
|
||
|
||
#### Drag & drop table
|
||
|
||
data:image/s3,"s3://crabby-images/c5a65/c5a652b750fc0c73e3c3fb0015c8f89e886cdf71" alt=""
|
||
|
||
#### Interactive table
|
||
|
||
data:image/s3,"s3://crabby-images/b834b/b834b7132065efe5c51b57f79b8446e519f4d238" alt=""
|
||
|
||
#### Uploading cropped avatar
|
||
|
||
data:image/s3,"s3://crabby-images/0ea7d/0ea7d599c3586faadd60060dd5410a05c19134d4" alt=""
|
||
|
||
#### Error log
|
||
|
||
data:image/s3,"s3://crabby-images/ed136/ed1362b4db767bbf3c56115b1446a95a42746a19" alt=""
|
||
|
||
#### Rich text (integrated with Qiniu, watermark and customization)
|
||
|
||
data:image/s3,"s3://crabby-images/84515/845150f74bc6c7e48872a01a9c9121788da633c1" alt=""
|
||
|
||
#### Packaging table component
|
||
|
||
data:image/s3,"s3://crabby-images/8c692/8c692d08ce8b348414a7101f09df6db40e86754e" alt=""
|
||
|
||
#### Charts
|
||
|
||
data:image/s3,"s3://crabby-images/d73c6/d73c6abfa197fa4aecae0163c12c23aa67c665e3" alt=""
|
||
|
||
#### Exporting to Excel
|
||
|
||
data:image/s3,"s3://crabby-images/f4f90/f4f904e45eaa66fb06fe0a1cb99440b699f983c9" alt=""
|
||
|
||
#### More
|
||
|
||
http://panjiachen.github.io/vue-element-admin
|
||
|
||
## License
|
||
|
||
MIT
|