1.电商后台管理功能
**
登录/退出功能
主页布局
用户管理模块
权限管理模块
参数管理模块
商品列表模块
订单管理模块
数据统计模块**
2.项目初始化
**
A. 安装Vue脚手架
B. 通过脚手架创建项目
C. 配置路由
D. 配置Element-UI:在插件中安装,搜索vue-cli-plugin-element
E. 配置Axios:在依赖中安装,搜索axios(运行依赖)
F. 初始化git仓库
G. 将本地项目托管到github或gitee(码云)中
**
配置好相关的功能之后然后写登录页面
这个登录页面需要写一定的配置啥的因为他这个用户名是通过接口文档获取的,只需要获取到相应的数据然后存在token即可
然后在登录页面获取相应的token
登陆成功页面
它这个左侧导航栏是可以隐藏的,然后就是在对应的标签设置flag
绑定一下就可以啦
<template>
<div class="about">
<el-container>
<el-header>
<h2>电商后台管理系统</h2>
<el-button type="info" @click="logOut">退出</el-button>
</el-header>
<el-container>
<el-aside :width="flag ? '64px' :'200px' ">
<p @click="flag = !flag">|||</p>
<!-- 左侧导航菜单 -->
<el-menu
default-active="2"
class="el-menu-vertical-demo"
background-color="#545c64"
text-color="#fff"
active-text-color="#ffd04b"
unique-opened
router
:collapse="flag"
collapse-transition
>
<el-submenu :index="item.id + ''" v-for="item in menuData" :key="item.id">
<template slot="title">
<i class="el-icon-location"></i>
<span>{{item.authName}}</span>
</template>
<el-menu-item-group>
<el-menu-item :index="it.path"
v-for="it in item.children"
@click="getBread(item.authName,it.authName)"
:key="it.id">{{it.authName}}</el-menu-item>
</el-menu-item-group>
</el-submenu>
</el-menu>
</el-aside>
<el-main>
<!-- 子级路由显示 -->
<router-view></router-view>
</el-main>
</el-container>
</el-container>
</div>
</template>
<script>
export default {
data() {
return {
flag:false,
// 菜单列表
menuData:[]
}
},
mounted() {
this.getMenu()
},
methods: {
// 退出
logOut(){
sessionStorage.removeItem('Login')
this.$message({
message: "恭喜你,退出成功",
type: "success",
});
this.$router.push("/login");
},
// 菜单
getMenu(){
this.$http.get('menus').then(res=>{
this.menuData = res.data.data
// console.log(res.data.data)
})
},
// 面包屑导航
getBread(one,two){
var obj = {one:one,two:two}
sessionStorage.setItem('bread',JSON.stringify(obj))
}
},
}
</script>
<style lang="scss">
.about,.el-container{
width: 100%;
height: 100%;
}
.el-header {
background-color: #373d41;
height: 80px !important;
color:#fff;
display: flex;
align-items: center;
.el-button{
position: absolute;
top:15px;
right: 40px;
}
}
.el-aside {
background-color: #545c64;
color: #333;
&>p{
color: #fff;
font-size: 14px;
text-align: center;
cursor: pointer;
}
}
.el-main {
background-color: #E9EEF3;
color: #333;
}
</style>
用户管理页面主要就是一些增删改查 好多地方都是相似的
因为之前这个项目做过老多次了,又不熟系的地方也在同学的帮助下写出来了
<template>
<div>
<!-- 面包屑导航 -->
<bread></bread>
<!-- 卡片 -->
<el-card class="box-card">
<!-- input -->
<el-input placeholder="请输入内容" v-model="user.query" clearable @clear="getUserList">
<el-button
slot="append"
icon="el-icon-search"
@click="getUserList"
></el-button
></el-input>
<el-button type="primary" @click="showDialog">添加用户</el-button>
<!-- 用户表格 -->
<el-table :data="userList" style="width: 100%">
<el-table-column type="index" width="50"> </el-table-column>
<el-table-column prop="username" label="姓名"> </el-table-column>
<el-table-column prop="email" label="邮箱"> </el-table-column>
<el-table-column prop="mobile" label="电话"> </el-table-column>
<el-table-column prop="role_name" label="角色"> </el-table-column>
<el-table-column label="状态">
<template prop="mg_state" v-slot="scope">
<el-switch
v-model="scope.row.mg_state"
active-color="#13ce66"
inactive-color="#ff4949"
@change="getChange(scope.row)"
>
</el-switch>
</template>
</el-table-column>
<el-table-column prop="date" label="操作">
<template v-slot="scope">
<el-button
type="primary"
icon="el-icon-edit"
circle
@click="editUser(scope.row)"
></el-button>
<el-button
type="danger"
icon="el-icon-delete"
circle
@click="removeUser(scope.row)"
></el-button>
<el-button type="warning" icon="el-icon-setting" circle></el-button>
</template>
</el-table-column>
</el-table>
<!-- 分页 -->
<el-pagination
@size-change="handleSizeChange"
@current-change="handleCurrentChange"
:current-page="user.pagenum"
:page-sizes="[3, 5, 10, 20, 30, 400]"
:page-size="user.pagesize"
layout="total, sizes, prev, pager, next, jumper"
:total="total"
>
</el-pagination>
</el-card>
<!-- 添加用户对话框 -->
<el-dialog title="收货地址" :visible.sync="dialogFormVisible">
<el-form :model="form" :rules="rules" ref="ruleForm">
<el-form-item label="用户名" prop="username">
<el-input v-model="form.username" autocomplete="off"></el-input>
</el-form-item>
<el-form-item label="密码" prop="password">
<el-input v-model="form.password" autocomplete="off"></el-input>
</el-form-item>
<el-form-item label="邮箱" prop="email">
<el-input v-model="form.email" autocomplete="off"></el-input>
</el-form-item>
<el-form-item label="电话" prop="mobile">
<el-input v-model="form.mobile" autocomplete="off"></el-input>
</el-form-item>
</el-form>
<div slot="footer" class="dialog-footer">
<el-button @click="dialogFormVisible = false">取 消</el-button>
<el-button type="primary" @click="addUser('ruleForm')">确 定</el-button>
</div>
</el-dialog>
<!-- 编辑用户对话框 -->
<el-dialog title="收货地址" :visible.sync="editFlag">
<el-form :model="editform" :rules="rules" ref="ruleForm">
<el-form-item label="用户名">
<el-input
v-model="editform.username"
autocomplete="off"
:disabled="true"
></el-input>
</el-form-item>
<el-form-item label="邮箱" prop="email">
<el-input v-model="editform.email" autocomplete="off"></el-input>
</el-form-item>
<el-form-item label="电话" prop="mobile">
<el-input v-model="editform.mobile" autocomplete="off"></el-input>
</el-form-item>
</el-form>
<div slot="footer" class="dialog-footer">
<el-button @click="editFlag = false">取 消</el-button>
<el-button type="primary" @click="addEdit('ruleForm')">确 定</el-button>
</div>
{{ editform }}
</el-dialog>
</div>
</template>
<script>
import bread from "@/components/Bread.vue";
import qs from "qs";
export default {
components: { bread },
data() {
return {
total: 0,
editFlag: false,
//用户数据列表
user: {
query: "",
pagenum: 1, //页数
pagesize: 3, //个数
},
userList: [],
dialogFormVisible: false,
form: {
username: "",
password: "",
email: "",
mobile: "",
},
// 编辑
editform: {
id: "",
username: "",
email: "",
mobile: "",
},
//表单验证
rules: {
username: [
{ required: true, message: "请输入用户名", trigger: "blur" },
{ min: 3, max: 5, message: "长度在 3 到 5 个字符", trigger: "blur" },
],
password: [
{ required: true, message: "请输入密码", trigger: "blur" },
{
min: 5,
max: 10,
message: "长度在 5 到 10 个字符",
trigger: "blur",
},
],
email: [
{ required: true, message: "请输入密码", trigger: "blur" },
{
min: 5,
max: 10,
message: "长度在 5 到 10 个字符",
trigger: "blur",
},
],
mobile: [
{ required: true, message: "请输入密码", trigger: "blur" },
{
min: 5,
max: 10,
message: "长度在 5 到 10 个字符",
trigger: "blur",
},
],
},
};
},
created() {},
mounted() {
this.getUserList();
},
methods: {
// 获取用户列表
async getUserList() {
let userList = qs.stringify(this.user);
let { data: res } = await this.$http.get("users?" + userList);
// console.log(res.data);
this.userList = res.data.users;
this.total = res.data.total;
},
// 添加用户,显示对话框
showDialog() {
this.dialogFormVisible = true;
},
//添加数据
addUser(formName) {
this.$refs[formName].validate(async (valid) => {
if (valid) {
let { data: res } = await this.$http.post("users", this.form);
// console.log(res.data);
this.dialogFormVisible = false;
if (res.meta.status == 200) {
this.$message({
message: "恭喜你,添加成功",
type: "success",
});
}
this.getUserList();
} else {
console.log("error submit!!");
return false;
}
});
},
// 分页
handleSizeChange(val) {
this.user.pagesize = val;
this.getUserList();
},
handleCurrentChange(val) {
this.user.pagenum = val;
this.getUserList();
},
// 修改用户状态
getChange(info) {
this.$http.put(`users/${info.id}/state/${info.mg_state}`).then((res) => {
console.log(res.data);
if (res.data.meta.status == 200) {
this.$message({
message: "修改成功",
type: "success",
});
}
});
},
// 编辑用户,数据回显
editUser(edit) {
this.editFlag = true;
this.editform = edit;
},
//编辑,更新数据
addEdit(formName) {
this.$refs[formName].validate(async (valid) => {
if (valid) {
this.$http
.put(`users/${this.editform.id}`, this.editform)
.then((res) => {
console.log(res.data);
if (res.data.meta.status == 200) {
this.$message({
message: "更新成功",
type: "success",
});
}
});
this.editFlag = false;
} else {
console.log("error submit!!");
return false;
}
});
},
// 删除
removeUser(rem) {
this.$confirm("此操作将永久删除该文件, 是否继续?", "提示", {
confirmButtonText: "确定",
cancelButtonText: "取消",
type: "warning",
})
.then(() => {
this.$http.delete(`users/${rem.id}`).then((res) => {
this.getUserList();
if (res.data.meta.status == 200) {
this.$message({
message: "删除成功",
type: "success",
});
}
});
})
.catch(() => {
this.$message({
type: "info",
message: "已取消删除",
});
});
},
},
};
</script>
<style scoped lang="scss">
.el-input {
width: 370px;
}
.el-table {
margin-top: 20px;
}
.el-button--primary {
margin-left: 20px;
}
</style>