详解Vue Elememt-UI构建管理后台
程序员文章站
2022-07-06 15:57:08
安装
我使用的是 vue-cli 初始化项目,命令如下:
npm i -g vue-cli
mkdir my-project && cd my-proje...
安装
我使用的是 vue-cli 初始化项目,命令如下:
npm i -g vue-cli mkdir my-project && cd my-project vue init webpack
修改 package.json 文件:
... "dependencies": { "vue": "^2.5.2", "vue-router": "^3.0.1", "element-ui": "^2.0.7", // element-ui "axios": "^0.17.1" // http 请求库 } ...
之后执行 npm install 进行安装依赖,如果安装速度有点慢的话,可以试一下 cnpm ,具体安装和用法自行查找。
简单介绍下项目的目录结构:
├─build // 构建配置 ├─config // 配置文件 ├─src // vue 开发源文件目录 ├────assets // css/js 文件 ├────components // vue 组件 ├────router // 路由 ├────app.vue // 启动组件 ├────main.js // 入口文件 ├─static // 静态文件目录 ├─test // 测试目录
之后在项目根目录执行 npm run dev ,打开浏览器输入 http://localhost:8080 就可以查看了。
目标
- 登录页面,登录,退出功能
- 首页,调用接口渲染列表
路由
路由使用的是 vue-router,具体用法可参考 官方文档
我们这里需要两个路由:
src/router/index.js
import vue from 'vue' import router from 'vue-router' import index from '@/components/index' import login from '@/components/login' vue.use(router) const routers = new router({ routes: [ { path: '/index', name: 'index', component: index }, { path: '/login', name: 'login', component: login } ] }) routers.beforeeach((to, from, next) => { if (to.name !== 'login' && !localstorage.getitem('token')) { next({path: 'login'}) } else { next() } }) export default routers
登录页面
src/components/login.vue
<template> <div class="login"> <el-form name="aa" :inline="true" label-position="right" label-width="80px"> <el-form-item label="用户名"> <el-input v-model="user.name"></el-input> </el-form-item> <el-form-item label="密码"> <el-input type="password" v-model="user.password"></el-input> </el-form-item> <el-form-item label=" "> <el-button type="primary" @click="login()">登录</el-button> </el-form-item> </el-form> </div> </template> <script> import $http from '@/api/' import config from '@/config' export default { data () { return { user: { name: '', password: '' } } }, mounted: function () { var token = localstorage.getitem('token') if (token) { this.$router.push('/index') } }, methods: { login: function () { var data = { grant_type: 'password', client_id: config.oauth_client_id, client_secret: config.oauth_secret, username: this.user.name, password: this.user.password } var _this = this $http.login(data).then(function (res) { if (res.status === 200) { $http.settoken(res.data.access_token) _this.$message({ showclose: false, message: '登录成功', type: 'success' }) _this.$router.push('/index') } else { _this.$message({ showclose: false, message: '登录失败', type: 'error' }) } }) } } } </script> <style> .login{ width: 300px; margin: 100px auto; background-color: #ffffff; padding: 30px 30px 5px; border-radius: 5px; } </style>
首页
src/components/index.vue
<template> <div class="main"> <el-table stripe v-loading="loading" element-loading-background="#dddddd" :data="tabledata" style="width: 100%"> <el-table-column prop="id" label="id"> </el-table-column> <el-table-column prop="name" label="名称"> </el-table-column> </el-table> <el-pagination background layout="prev, pager, next" :total="total" class="page" @current-change="pagelist"> </el-pagination> </div> </template> <script> import $http from '@/api/' export default { data () { return { tabledata: [], total: 0, loading: false } }, mounted: function () { this.getlist() }, methods: { pagelist: function (page) { this.search.page = page this.getlist() }, getlist: function () { var _this = this _this.loading = true $http.index().then(function (res) { if (res.status === 200) { _this.tabledata = res.data.data.lists _this.total = res.data.data.total } _this.loading = false }) } } } </script>
app
src/app.vue
<template> <div id="app"> <el-row v-if="token"> <menus class="left-menu"> <h3 class="logo"><a href="/" rel="external nofollow" >admin</a></h3> </menus> <el-col :span="21" :gutter="0" :offset="3"> <el-breadcrumb separator-class="el-icon-arrow-right" class="breadcrumb"> <el-breadcrumb-item :to="{ path: '/' }">首页</el-breadcrumb-item> <el-breadcrumb-item class="active">列表</el-breadcrumb-item> </el-breadcrumb> <el-dropdown @command="operate" class="header"> <img src="/static/image/head.jpg" /> <el-dropdown-menu slot="dropdown" :click="true"> <el-dropdown-item command="/user/profile">基本资料</el-dropdown-item> <el-dropdown-item command="/logout">安全退出</el-dropdown-item> </el-dropdown-menu> </el-dropdown> <router-view/> </el-col> <el-col :span="21" :gutter="0" :offset="3" class="footer">copyright © 2017 flyerboy all rights reserved</el-col> </el-row> <router-view v-if="!token" /> </div> </template> <script> import menus from '@/components/menu' export default { name: 'app', data () { return { token: false } }, mounted: function () { this.token = localstorage.getitem('token') ? true : false }, watch: { '$route.path': function ($newval, $oldval) { this.token = localstorage.getitem('token') ? true : false } }, methods: { operate: function (command) { if (command === '/logout') { localstorage.removeitem('token') this.$router.push('login') } else { this.$router.push(command) } } }, components: { menus } } </script> <style> body{ margin: 0; padding: 0; background-color: #eeeeee; } .header{ position: absolute; top: 5px; right: 20px; } .header img{ width: 38px; height: 38px; border-radius: 20px; border: 1px solid #aaaaaa; } #app { font-family: 'avenir', helvetica, arial, sans-serif; -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; } .main{ padding: 20px; min-height: 600px; margin-bottom: 20px; } .main table{ background: #ffffff; } .left-menu{ background-color: #33374b; } .logo{ padding: 20px 0 15px 20px; font-size: 24px; border-bottom: 2px solid #3a8ee6; } .logo a{ color: #ffffff; text-decoration: none; } .left-menu .el-menu{ border-right: 0; } .breadcrumb{ line-height: 40px; padding: 5px 20px; background: #ffffff; } .breadcrumb span{ color: #069; font-weight: normal; } .breadcrumb .active{ color: #aaaaaa; } .page{ margin: 20px 0 0; margin-left: -10px; } .page .el-pager li.number{ background-color: #ffffff; } .el-submenu .el-menu-item{ padding-left: 60px !important; } .footer{ position: fixed; bottom: 0; right: 0; font-size: 12px; color: #888888; padding: 15px 20px; text-align: center; background-color: #ffffff; margin-top: 40px; } </style>
调用 api
src/api/index.js
import axios from 'axios' axios.defaults.baseurl = 'http://localhost:8000/' axios.defaults.headers.post['content-type'] = 'application/x-www-form-urlencoded' axios.defaults.headers.common['authorization'] = 'bearer ' + localstorage.getitem('token') export default { settoken: function (token) { localstorage.setitem('token', token) axios.defaults.headers.common['authorization'] = 'bearer ' + token }, login: function (param) { return axios.post('oauth/token', param) }, index: function (params) { return axios.get('api/user/list', { params: params }) } }
config
src/config.js 这里配置登录 oauth 需要的 client_id 和 secret
export default { oauth_client_id: 2, oauth_secret: '' }
main.js
src/main.js
import vue from 'vue' import app from './app' import router from './router' import elementui from 'element-ui' import 'element-ui/lib/theme-chalk/index.css' vue.use(elementui) vue.config.productiontip = false new vue({ el: '#app', router, components: { app }, template: '<app/>' })
api 接口
主要用到两个接口,一个是 api/oauth/token 登录获取 token 接口,一个获取列表 api/user/list。
第一个接口是用到 laravel oauth,第二个接口直接是一个简单的查询用户列表接口,详细讲会在下一篇文章中讲述。
以上就是本次整理的关于vue elememt-ui构建管理后台的全部内容,感谢大家对的支持。
上一篇: 谷歌浏览器下载文件的默认保存位置如何修改
推荐阅读
-
vue+gin golang快速开发全栈后台管理系统模板
-
vue后台管理系统项目注意事项(二)------router.js
-
vue3如何使用provide实现状态管理详解
-
vue3 + elementplus后台管理系统 + vue3核心Api实现 + Vuex4从零实现
-
Vue+elementui的后台管理系统模板解析
-
构建ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统(24)-权限管理系统-将权限授权给角色
-
详解vue2.0模拟后台json数据
-
vue 搭建后台系统模块化开发详解
-
ASP.NET MVC4+EF5+EasyUI+Unity2.x注入的后台管理系统之前端页面框架构建源码分享
-
使用Vue.observable()进行状态管理的实例代码详解