电商后台管理(一)

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>

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值