zoukankan      html  css  js  c++  java
  • 前后端分离开发vue+Elementyui+abpcorewebapi商城管理系统(六)用户列表页面

    页面分析

     

    后台数据格式

     完整代码

    <template>
      <div>
        <el-breadcrumb separator-class="el-icon-arrow-right">
          <el-breadcrumb-item :to="{ path: '/home' }">首页</el-breadcrumb-item>
          <el-breadcrumb-item>用户管理</el-breadcrumb-item>
          <el-breadcrumb-item>用户列表</el-breadcrumb-item>
        </el-breadcrumb>
        <el-card>
          <el-row :gutter="20">
            <el-col :span="7">
              <el-input
                placeholder="请输入内容"
                clearable
                @clear="getUserList"
                v-model="queryInfo.query"
              >
                <el-button
                  slot="append"
                  icon="el-icon-search"
                  @click="getUserList"
                ></el-button>
              </el-input>
            </el-col>
            <el-col :span="4">
              <el-button type="primary" @click="dialogVisible = true"
                >添加用户</el-button
              >
            </el-col>
          </el-row>
          <el-table :data="userlist" border stripe style=" 100%">
            <el-table-column type="index"></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 v-slot="scope">
                <el-switch
                  v-model="scope.row.mg_state"
                  @change="userStateChanged(scope.row)"
                ></el-switch>
              </template>
            </el-table-column>
            <el-table-column label="操作">
              <!-- 编辑用户 -->
              <template v-slot="scope">
                <el-button
                  type="primary"
                  icon="el-icon-edit"
                  @click="showEditDialog(scope.row.id)"
                  size="mini"
                ></el-button>
                <!-- 删除用户 -->
                <el-button
                  type="danger"
                  @click="deleteUser(scope.row.id)"
                  icon="el-icon-delete"
                  size="mini"
                ></el-button>
                <!-- 分配角色 -->
                <el-tooltip
                  :enterable="false"
                  effect="dark"
                  content="分配角色"
                  placement="top-start"
                >
                  <el-button
                    type="warning"
                    icon="el-icon-setting"
                    size="mini"
                    @click="setRole(scope.row)"
                  ></el-button>
                </el-tooltip>
              </template>
            </el-table-column>
          </el-table>
          <el-pagination
            @size-change="handleSizeChange"
            @current-change="handleCurrentChange"
            :current-page="queryInfo.pagenum"
            :page-sizes="[1, 2, 5, 10]"
            :page-size="queryInfo.pagesize"
            layout="total, sizes, prev, pager, next, jumper"
            :total="total"
          ></el-pagination>
        </el-card>
    
        <!-- 添加用户对话框 -->
        <el-dialog
          title="添加用户"
          :visible.sync="dialogVisible"
          width="50%"
          @close="addDialogClosed"
        >
          <el-form
            :model="addUserForm"
            :rules="addUserFormRules"
            ref="addUserFormRef"
            label-width="70px"
            class="demo-ruleForm"
          >
            <el-form-item label="用户名" prop="username">
              <el-input v-model="addUserForm.username"></el-input>
            </el-form-item>
            <el-form-item label="密码" prop="password">
              <el-input v-model="addUserForm.password"></el-input>
            </el-form-item>
            <el-form-item label="邮箱" prop="email">
              <el-input v-model="addUserForm.email"></el-input>
            </el-form-item>
            <el-form-item label="手机" prop="mobile">
              <el-input v-model="addUserForm.mobile"></el-input>
            </el-form-item>
          </el-form>
          <span slot="footer" class="dialog-footer">
            <el-button @click="dialogVisible = false">取 消</el-button>
            <el-button type="primary" @click="addUser">确 定</el-button>
          </span>
        </el-dialog>
    
        <!-- 修改用户对话框 -->
        <el-dialog
          title="修改用户"
          :visible.sync="editDialogVisible"
          width="50%"
          @close="editDialogClosed"
        >
          <el-form
            :model="editUserForm"
            :rules="editUserFormRules"
            ref="editUserFormRef"
            label-width="70px"
            class="demo-ruleForm"
          >
            <el-form-item label="用户名">
              <el-input v-model="editUserForm.username" disabled></el-input>
            </el-form-item>
            <el-form-item label="邮箱" prop="email">
              <el-input v-model="editUserForm.email"></el-input>
            </el-form-item>
            <el-form-item label="手机" prop="mobile">
              <el-input v-model="editUserForm.mobile"></el-input>
            </el-form-item>
          </el-form>
          <span slot="footer" class="dialog-footer">
            <el-button @click="editDialogVisible = false">取 消</el-button>
            <el-button type="primary" @click="editUser">确 定</el-button>
          </span>
        </el-dialog>
    
        <!-- 分配角色对话框 -->
        <el-dialog
          title="分配角色"
          :visible.sync="setRoleDialogVisible"
          @close="setRoleDialogClosed"
          width="50%"
        >
          <div>
            <p>当前的用户:{{ userInfo.username }}</p>
            <p>当前的角色:{{ userInfo.role_name }}</p>
            <p>分配新角色:
              <el-select v-model="selectRoleId" placeholder="请选择新角色">
                <el-option
                  v-for="item in rolesList"
                  :key="item.id"
                  :label="item.roleName"
                  :value="item.id">
                </el-option>
              </el-select>
            </p>
          </div>
          <div slot="footer">
            <el-button @click="setRoleDialogVisible = false">取 消</el-button>
            <el-button type="primary" @click="saveRoleInfo"
              >确 定</el-button
            >
          </div>
        </el-dialog>
      </div>
    </template>
    
    <script>
    export default {
      data() {
        // 自定义邮箱校验规则
        var checkEmail = (rule, value, cb) => {
          const regEail = /^[A-Za-zd]+([-_.][A-Za-zd]+)*@([A-Za-zd]+[-.])+[A-Za-zd]{2,4}$/;
          if (regEail.test(value)) {
            return cb();
          }
          cb(new Error("请输入合法的邮箱"));
        };
        // 自定义手机号校验规则
        var checkMobile = (rule, value, cb) => {
          const regMobile = /^[1][3,4,5,7,8][0-9]{9}$/;
          if (regMobile.test(value)) {
            return cb();
          }
          cb(new Error("请输入合法的手机号"));
        };
        return {
          queryInfo: {
            query: "",
            pagenum: 1,
            pagesize: 2
          },
          userlist: [],
          total: 0,
          dialogVisible: false,
          editDialogVisible: false,
          addUserForm: {
            username: "",
            password: "",
            email: "",
            mobile: ""
          },
          setRoleDialogVisible: false,
          addUserFormRules: {
            username: [
              { required: true, message: "请输入用户名", trigger: "blur" },
              {
                require: true,
                min: 3,
                max: 10,
                message: "用户名长度在 3 到 10 个字符",
                trigger: "blur"
              }
            ],
            password: [
              { required: true, message: "请输入密码", trigger: "blur" },
              {
                require: true,
                min: 6,
                max: 15,
                message: "密码长度在 6 到 15 个字符",
                trigger: "blur"
              }
            ],
            email: [
              { required: true, message: "请输入邮箱", trigger: "blur" },
              { validator: checkEmail, trigger: "blur" }
            ],
            mobile: [
              { required: true, message: "请输入手机", trigger: "blur" },
              { validator: checkMobile, trigger: "blur" }
            ]
          },
          editUserForm: {},
          editUserFormRules: {
            email: [
              { required: true, message: "请输入邮箱", trigger: "blur" },
              { validator: checkEmail, trigger: "blur" }
            ],
            mobile: [
              { required: true, message: "请输入手机", trigger: "blur" },
              { validator: checkMobile, trigger: "blur" }
            ]
          },
          userInfo: "",
          rolesList: [],
          selectRoleId:''
        };
      },
      methods: {
        async getUserList() {
          const { data } = await this.$http.get("users", {
            params: this.queryInfo
          });
          this.userlist = data.data.users;
          this.total = data.data.total;
        },
        handleSizeChange(newSize) {
          this.queryInfo.pagesize = newSize;
          this.getUserList();
        },
        handleCurrentChange(newPage) {
          this.queryInfo.pagenum = newPage;
          this.getUserList();
        },
        async userStateChanged(userinfo) {
          const { data } = await this.$http.put(
            `/users/${userinfo.id}/state/${userinfo.mg_state}`
          );
          if (data.meta.status !== 200) {
            this.$message.error("获取信息失败!");
          }else{
            this.$message.success("修改状态成功!");
          }
        },
        addDialogClosed() {
          this.$refs.addUserFormRef.resetFields();
        },
        addUser() {
          this.$refs.addUserFormRef.validate(async valid => {
            if (!valid) return;
            const { data } = await this.$http.post("users", this.addUserForm);
            if (data.meta.status !== 201) {
              this.$message.error("添加用户失败!");
            }
            this.$message.success("添加用户成功!");
            this.dialogVisible = false;
            this.getUserList();
          });
        },
        async showEditDialog(id) {
          const { data } = await this.$http.get(`users/${id}`);
          if (data.meta.status !== 200) {
            this.$message.error("查询用户失败!");
          }
          this.editUserForm = data.data;
          this.editDialogVisible = true;
        },
        editDialogClosed() {
          this.$refs.editUserFormRef.resetFields();
        },
        editUser() {
          this.$refs.editUserFormRef.validate(async valid => {
            if (!valid) return;
            const { data } = await this.$http.put(`users/${this.editUserForm.id}`, {
              email: this.editUserForm.email,
              mobile: this.editUserForm.mobile
            });
            if (data.meta.status !== 200) {
              this.$message.error("修改用户信息失败!");
            }
            this.$message.success("修改成功!");
            this.editDialogVisible = false;
            this.getUserList();
          });
        },
        deleteUser(id) {
          this.$confirm("此操作将永久删除该用户, 是否继续?", "提示", {
            confirmButtonText: "确定",
            cancelButtonText: "取消",
            type: "warning"
          })
            .then(async () => {
              const { data } = await this.$http.delete(`users/${id}`);
              if (data.meta.status !== 200) {
                this.$message.error(data.meta.msg);
              } else {
                this.$message({
                  type: "success",
                  message: "删除成功!"
                });
                this.getUserList();
              }
            })
            .catch(() => {
              this.$message({
                type: "info",
                message: "已取消删除"
              });
            });
        },
        async setRole(userInfo) {
          const { data } = await this.$http.get("roles");
          if (data.meta.status !== 200) {
            return this.$message.error(data.meta.msg);
          }
          this.rolesList = data.data
          this.userInfo = userInfo;
          this.setRoleDialogVisible = true;
        },
        async saveRoleInfo() {
          if(!this.selectRoleId) {
            return this.$message.error('请选择要分配的角色!')
          }
          const {data} = await this.$http.put(`users/${this.userInfo.id}/role`,{
            rid:this.selectRoleId
          })
          if(data.meta.status!==200) {
            return this.$message.error(data.meta.msg)
          }
          this.$message.success('分配角色成功!')
          this.getUserList();
          this.setRoleDialogVisible = false
        },
        setRoleDialogClosed() {
          this.selectRoleId = '',
          this.userInfo = {}
        }
      },
      created() {
        this.getUserList();
      }
    };
    </script>
    
    <style lang="less" scoped></style>
  • 相关阅读:
    简单好用的日历排期控件
    Ext.js create store
    Ext.js页面添加元素
    Ext.js Tree
    前端设计的七大法则
    如何写软件开发相关文档,它包含哪些种类和内容
    行内文字末尾下降
    正则表达式
    滚动加载数据
    location.hash来保持页面状态
  • 原文地址:https://www.cnblogs.com/xiewenyu/p/13099519.html
Copyright © 2011-2022 走看看