若依框架 -------- vue3+element-plus(四)

简介: 若依框架 -------- vue3+element-plus(四)

后端管理系统,前后端分离的框架若依管理后台,来看下vue3+element-plus版本。


实现一个页面


定义api请求


gatewayPath 分布式网关定义

import request from '@/utils/request'
import { gatewayPath } from '@/utils/gateway';
// 网关路径
const adminApi = gatewayPath.adminApi || '';
// 查询用户列表
export function listUser(query) {
  return request({
    url: adminApi + '/api/account/user/list',
    method: 'get',
    params: query
  })
}
// 查询用户详细
export function getUser(id) {
  return request({
    url: adminApi + '/api/account/user/' + id,
    method: 'get'
  })
}
// 新增用户
export function addUser(data) {
  return request({
    url: adminApi + '/api/account/user',
    method: 'post',
    data: data
  })
}
// 修改用户
export function updateUser(data) {
  return request({
    url: adminApi + '/api/account/user',
    method: 'post',
    data: data
  })
}
// 删除用户
export function delUser(id) {
  return request({
    url: adminApi + '/api/account/user/' + id,
    method: 'post'
  })
}


页面实现 views/account/appUser

<template>
  <div class="app-container">
    <el-form :model="queryParams" ref="queryForm" :inline="true" v-show="showSearch" label-width="68px">
      <el-form-item label="姓名" prop="userName">
        <el-input
          v-model="queryParams.userName"
          placeholder="请输入姓名"
          clearable
          size="small"
        />
      </el-form-item>
      <el-form-item label="用户手机号" prop="userPhone">
        <el-input
          v-model="queryParams.userPhone"
          placeholder="请输入用户手机号"
          clearable
          size="small"
        />
      </el-form-item>
      <el-form-item label="用户二维码标识" prop="qrCode">
        <el-input
          v-model="queryParams.qrCode"
          placeholder="请输入用户二维码标识"
          clearable
          size="small"
        />
      </el-form-item>
      <el-form-item label="性别" prop="gender">
        <el-input
          v-model="queryParams.gender"
          placeholder="请输入性别"
          clearable
          size="small"
        />
      </el-form-item>
      <el-form-item label="生日" prop="birthday">
        <el-date-picker clearable size="small"
          v-model="queryParams.birthday"
          type="date"
          value-format="yyyy-MM-dd"
          placeholder="选择生日">
        </el-date-picker>
      </el-form-item>
      <el-form-item label="身份证号" prop="idCardNo">
        <el-input
          v-model="queryParams.idCardNo"
          placeholder="请输入身份证号"
          clearable
          size="small"
        />
      </el-form-item>
      <el-form-item label="身份证正面照" prop="idCardFront">
        <el-input
          v-model="queryParams.idCardFront"
          placeholder="请输入身份证正面照"
          clearable
          size="small"
        />
      </el-form-item>
      <el-form-item label="身份证反面照" prop="idCardReverse">
        <el-input
          v-model="queryParams.idCardReverse"
          placeholder="请输入身份证反面照"
          clearable
          size="small"
        />
      </el-form-item>
      <el-form-item label="昵称" prop="nickname">
        <el-input
          v-model="queryParams.nickname"
          placeholder="请输入昵称"
          clearable
          size="small"
        />
      </el-form-item>
      <el-form-item label="头像" prop="avatar">
        <el-input
          v-model="queryParams.avatar"
          placeholder="请输入头像"
          clearable
          size="small"
        />
      </el-form-item>
      <el-form-item label="登陆密码" prop="loginPwd">
        <el-input
          v-model="queryParams.loginPwd"
          placeholder="请输入登陆密码"
          clearable
          size="small"
        />
      </el-form-item>
      <el-form-item label="支付密码" prop="payPwd">
        <el-input
          v-model="queryParams.payPwd"
          placeholder="请输入支付密码"
          clearable
          size="small"
        />
      </el-form-item>
      <el-form-item label="注册类型" prop="wxOpenId">
        <el-input
          v-model="queryParams.wxOpenId"
          placeholder="请输入注册类型"
          clearable
          size="small"
        />
      </el-form-item>
      <el-form-item label="修改时间" prop="updateTime">
        <el-date-picker clearable size="small"
          v-model="queryParams.updateTime"
          type="date"
          value-format="yyyy-MM-dd"
          placeholder="选择修改时间">
        </el-date-picker>
      </el-form-item>
      <el-form-item label="0无效1有效" prop="yn">
        <el-input
          v-model="queryParams.yn"
          placeholder="请输入0无效1有效"
          clearable
          size="small"
        />
      </el-form-item>
      <el-form-item label="备注" prop="remark">
        <el-input
          v-model="queryParams.remark"
          placeholder="请输入备注"
          clearable
          size="small"
        />
      </el-form-item>
      <el-form-item>
        <el-button type="primary" icon="el-icon-search" size="mini" @click="handleQuery">搜索</el-button>
        <el-button icon="el-icon-refresh" size="mini" @click="resetQuery">重置</el-button>
      </el-form-item>
    </el-form>
    <el-row :gutter="10" class="mb8">
      <el-col :span="1.5">
        <el-button
          type="primary"
          plain
          icon="el-icon-plus"
          size="mini"
          @click="handleAdd"
          v-hasPermi="['biz:user:add']"
        >新增</el-button>
      </el-col>
      <el-col :span="1.5">
        <el-button
          type="success"
          plain
          icon="el-icon-edit"
          size="mini"
          :disabled="single"
          @click="handleUpdate"
          v-hasPermi="['biz:user:edit']"
        >修改</el-button>
      </el-col>
      <el-col :span="1.5">
        <el-button
          type="danger"
          plain
          icon="el-icon-delete"
          size="mini"
          :disabled="multiple"
          @click="handleDelete"
          v-hasPermi="['biz:user:remove']"
        >删除</el-button>
      </el-col>
      <el-col :span="1.5">
        <el-button
          type="warning"
          plain
          icon="el-icon-download"
          size="mini"
          @click="handleExport"
          v-hasPermi="['biz:user:export']"
        >导出</el-button>
      </el-col>
      <right-toolbar :showSearch="showSearch" @queryTable="getList"></right-toolbar>
    </el-row>
    <el-table v-loading="loading" :data="userList" @selection-change="handleSelectionChange">
      <el-table-column type="selection" width="55" align="center" />
      <el-table-column label="主键" align="center" prop="id" />
      <el-table-column label="姓名" align="center" prop="userName" />
      <el-table-column label="用户手机号" align="center" prop="userPhone" />
      <el-table-column label="用户二维码标识" align="center" prop="qrCode" />
      <el-table-column label="性别" align="center" prop="gender" />
      <el-table-column label="生日" align="center" prop="birthday" width="180">
        <template #default="scope">
          <span>{{ parseTime(scope.row.birthday, '{y}-{m}-{d}') }}</span>
        </template>
      </el-table-column>
      <el-table-column label="身份证号" align="center" prop="idCardNo" />
      <el-table-column label="身份证正面照" align="center" prop="idCardFront" />
      <el-table-column label="身份证反面照" align="center" prop="idCardReverse" />
      <el-table-column label="昵称" align="center" prop="nickname" />
      <el-table-column label="头像" align="center" prop="avatar" />
      <el-table-column label="登陆密码" align="center" prop="loginPwd" />
      <el-table-column label="支付密码" align="center" prop="payPwd" />
      <el-table-column label="注册类型" align="center" prop="wxOpenId" />
      <el-table-column label="修改时间" align="center" prop="updateTime" width="180">
        <template #default="scope">
          <span>{{ parseTime(scope.row.updateTime, '{y}-{m}-{d}') }}</span>
        </template>
      </el-table-column>
      <el-table-column label="0无效1有效" align="center" prop="yn" />
      <el-table-column label="备注" align="center" prop="remark" />
      <el-table-column label="操作" align="center" class-name="small-padding fixed-width">
        <template #default="scope">
          <el-button
            size="mini"
            type="text"
            icon="el-icon-edit"
            @click="handleUpdate(scope.row)"
            v-hasPermi="['biz:user:edit']"
          >修改</el-button>
          <el-button
            size="mini"
            type="text"
            icon="el-icon-delete"
            @click="handleDelete(scope.row)"
            v-hasPermi="['biz:user:remove']"
          >删除</el-button>
        </template>
      </el-table-column>
    </el-table>
    <pagination
      v-show="total>0"
      :total="total"
      :page="queryParams.pageNum"
      :limit="queryParams.pageSize"
      @pagination="getList"
    />
    <!-- 添加或修改用户对话框 -->
    <el-dialog :title="title" width="500px" append-to-body :modelValue="open" >
      <el-form ref="form" :model="form" :rules="rules" label-width="80px">
        <el-form-item label="姓名" prop="userName">
          <el-input v-model="form.userName" placeholder="请输入姓名" />
        </el-form-item>
        <el-form-item label="用户手机号" prop="userPhone">
          <el-input v-model="form.userPhone" placeholder="请输入用户手机号" />
        </el-form-item>
        <el-form-item label="用户二维码标识" prop="qrCode">
          <el-input v-model="form.qrCode" placeholder="请输入用户二维码标识" />
        </el-form-item>
        <el-form-item label="性别" prop="gender">
          <el-input v-model="form.gender" placeholder="请输入性别" />
        </el-form-item>
        <el-form-item label="生日" prop="birthday">
          <el-date-picker clearable size="small"
            v-model="form.birthday"
            type="date"
            value-format="yyyy-MM-dd"
            placeholder="选择生日">
          </el-date-picker>
        </el-form-item>
        <el-form-item label="身份证号" prop="idCardNo">
          <el-input v-model="form.idCardNo" placeholder="请输入身份证号" />
        </el-form-item>
        <el-form-item label="身份证正面照" prop="idCardFront">
          <el-input v-model="form.idCardFront" placeholder="请输入身份证正面照" />
        </el-form-item>
        <el-form-item label="身份证反面照" prop="idCardReverse">
          <el-input v-model="form.idCardReverse" placeholder="请输入身份证反面照" />
        </el-form-item>
        <el-form-item label="昵称" prop="nickname">
          <el-input v-model="form.nickname" placeholder="请输入昵称" />
        </el-form-item>
        <el-form-item label="头像" prop="avatar">
          <el-input v-model="form.avatar" placeholder="请输入头像" />
        </el-form-item>
        <el-form-item label="登陆密码" prop="loginPwd">
          <el-input v-model="form.loginPwd" placeholder="请输入登陆密码" />
        </el-form-item>
        <el-form-item label="支付密码" prop="payPwd">
          <el-input v-model="form.payPwd" placeholder="请输入支付密码" />
        </el-form-item>
        <el-form-item label="注册类型" prop="wxOpenId">
          <el-input v-model="form.wxOpenId" placeholder="请输入注册类型" />
        </el-form-item>
        <el-form-item label="0无效1有效" prop="yn">
          <el-input v-model="form.yn" placeholder="请输入0无效1有效" />
        </el-form-item>
        <el-form-item label="备注" prop="remark">
          <el-input v-model="form.remark" placeholder="请输入备注" />
        </el-form-item>
      </el-form>
      <template #foot>
          <div class="dialog-footer">
            <el-button type="primary" @click="submitForm">确 定</el-button>
            <el-button @click="cancel">取 消</el-button>
          </div>
      </template>
    </el-dialog>
  </div>
</template>
<script setup name="AppUser">
import { ref } from "vue";
import { listUser, getUser, delUser, addUser, updateUser } from "@/api/account/appUser";
const { proxy } = getCurrentInstance();
      // 遮罩层
      const loading = ref(true);
      // 选中数组
      const ids = ref([]);
      // 非单个禁用
      const single = ref(true);
      // 非多个禁用
      const multiple = ref(true);
      // 显示搜索条件
      const showSearch = ref(true);
      // 总条数
      const total = ref(0);
      // 用户表格数据
      const userList  = ref([]);
      // 弹出层标题
      const title  = ref("");
      // 是否显示弹出层
      const open  = ref(false);
      // 查询参数
     const queryParamsData  = reactive({
        pageNum: 1,
        pageSize: 10,
        userName: null,
        userPhone: null,
        qrCode: null,
        gender: null,
        birthday: null,
        idCardNo: null,
        idCardFront: null,
        idCardReverse: null,
        nickname: null,
        avatar: null,
        loginPwd: null,
        payPwd: null,
        wxOpenId: null,
        updateTime: null,
        yn: null,
        remark: null
      });
      const queryParams = toRefs(queryParamsData);
      // 表单参数
      const formData = reactive({});
      const form = toRefs(formData);
      // 表单校验
      const rulesData = reactive({
        userName: [
          { required: true, message: "姓名不能为空", trigger: "blur" }
        ],
        qrCode: [
          { required: true, message: "用户二维码标识不能为空", trigger: "blur" }
        ],
        gender: [
          { required: true, message: "性别不能为空", trigger: "blur" }
        ],
        idCardNo: [
          { required: true, message: "身份证号不能为空", trigger: "blur" }
        ],
        idCardFront: [
          { required: true, message: "身份证正面照不能为空", trigger: "blur" }
        ],
        idCardReverse: [
          { required: true, message: "身份证反面照不能为空", trigger: "blur" }
        ],
        nickname: [
          { required: true, message: "昵称不能为空", trigger: "blur" }
        ],
        avatar: [
          { required: true, message: "头像不能为空", trigger: "blur" }
        ],
        loginPwd: [
          { required: true, message: "登陆密码不能为空", trigger: "blur" }
        ],
        payPwd: [
          { required: true, message: "支付密码不能为空", trigger: "blur" }
        ],
        wxOpenId: [
          { required: true, message: "注册类型不能为空", trigger: "blur" }
        ],
        createBy: [
          { required: true, message: "创建人不能为空", trigger: "blur" }
        ],
      });
      const  rules = toRefs(rulesData);
    /** 查询用户列表 */
   function getList() {
     loading.value = true;
      listUser(queryParams.value).then(response => {
        userList.value = response.rows;
        total.value = response.total;
        loading.value = false;
      });
    }
    // 取消按钮
    function cancel() {
      open.value = false;
      reset();
    }
    // 表单重置
    function reset() {
      form.value = {
        id: null,
        userName: null,
        userPhone: null,
        qrCode: null,
        gender: null,
        birthday: null,
        idCardNo: null,
        idCardFront: null,
        idCardReverse: null,
        nickname: null,
        avatar: null,
        loginPwd: null,
        payPwd: null,
        wxOpenId: null,
        createBy: null,
        createTime: null,
        updateBy: null,
        updateTime: null,
        yn: null,
        remark: null
      };
      resetForm("form");
    }
    /** 搜索按钮操作 */
   function handleQuery() {
      queryParams.value.pageNum = 1;
      getList();
    }
    /** 重置按钮操作 */
    function resetQuery() {
      resetForm("queryForm");
      handleQuery();
    }
    // 多选框选中数据
    function handleSelectionChange(selection) {
      ids.value = selection.map(item => item.id)
      single.value = selection.length!==1
      multiple.value = !selection.length
    }
    /** 新增按钮操作 */
    function handleAdd() {
      reset();
      open.value = true;
      title.value = "添加用户";
    }
    /** 修改按钮操作 */
    function handleUpdate(row) {
      reset();
      const id = row.id || ids.value
      getUser(id).then(response => {
        form.value = response.data;
        open.value = true;
        title.value = "修改用户";
      });
    }
    /** 提交按钮 */
    function submitForm() {
      proxy.$refs["form"].validate(valid => {
        if (valid) {
          if (form.value.id != null) {
            updateUser(form.value).then(response => {
              proxy.$modal.msgSuccess("修改成功");
              open.value = false;
              getList();
            });
          } else {
            addUser(form.value).then(response => {
              proxy.$modal.msgSuccess("新增成功");
              open.value = false;
              getList();
            });
          }
        }
      });
    }
    /** 删除按钮操作 */
   function handleDelete(row) {
      const ids = row.id || ids.value;
      proxy.$modal.confirm('是否确认删除用户编号为"' + ids + '"的数据项?').then(function() {
        return delUser(ids);
      }).then(() => {
        getList();
        proxy.$modal.msgSuccess("删除成功");
      }).catch(() => {});
    }
   /** 导出按钮操作 */
   function handleExport() {
      download('biz/user/export', {
        ...queryParams.value
      }, `user_${new Date().getTime()}.xlsx`)
    }
   /** 初始化数据 **/
   getList();
</script>


菜单及页面路由在后台配置

INSERT INTO ry.sys_menu (menu_name,parent_id,order_num,`path`,component,query,is_frame,is_cache,menu_type,visible,status,perms,icon,create_by,create_time,update_by,update_time,remark) VALUES
   ('角色管理',1,2,'role','system/role/index','',1,0,'C','0','0','system:role:list','peoples','admin','2022-01-12 12:13:41','',NULL,'角色管理菜单');


管理后台可以通过generator快速生成页面代码,稍加修改及可完成基础操作。


框架页面使用完成。

目录
相关文章
|
22天前
|
缓存 JavaScript UED
Vue3中v-model在处理自定义组件双向数据绑定时有哪些注意事项?
在使用`v-model`处理自定义组件双向数据绑定时,要仔细考虑各种因素,确保数据的准确传递和更新,同时提供良好的用户体验和代码可维护性。通过合理的设计和注意事项的遵循,能够更好地发挥`v-model`的优势,实现高效的双向数据绑定效果。
126 64
|
22天前
|
JavaScript 前端开发 API
Vue 3 中 v-model 与 Vue 2 中 v-model 的区别是什么?
总的来说,Vue 3 中的 `v-model` 在灵活性、与组合式 API 的结合、对自定义组件的支持等方面都有了明显的提升和改进,使其更适应现代前端开发的需求和趋势。但需要注意的是,在迁移过程中可能需要对一些代码进行调整和适配。
101 60
|
22天前
|
前端开发 JavaScript 测试技术
Vue3中v-model在处理自定义组件双向数据绑定时,如何避免循环引用?
Web 组件化是一种有效的开发方法,可以提高项目的质量、效率和可维护性。在实际项目中,要结合项目的具体情况,合理应用 Web 组件化的理念和技术,实现项目的成功实施和交付。通过不断地探索和实践,将 Web 组件化的优势充分发挥出来,为前端开发领域的发展做出贡献。
28 8
|
21天前
|
存储 JavaScript 数据管理
除了provide/inject,Vue3中还有哪些方式可以避免v-model的循环引用?
需要注意的是,在实际开发中,应根据具体的项目需求和组件结构来选择合适的方式来避免`v-model`的循环引用。同时,要综合考虑代码的可读性、可维护性和性能等因素,以确保系统的稳定和高效运行。
21 1
|
21天前
|
JavaScript
Vue3中使用provide/inject来避免v-model的循环引用
`provide`和`inject`是 Vue 3 中非常有用的特性,在处理一些复杂的组件间通信问题时,可以提供一种灵活的解决方案。通过合理使用它们,可以帮助我们更好地避免`v-model`的循环引用问题,提高代码的质量和可维护性。
32 1
|
22天前
|
JavaScript
在 Vue 3 中,如何使用 v-model 来处理自定义组件的双向数据绑定?
需要注意的是,在实际开发中,根据具体的业务需求和组件设计,可能需要对上述步骤进行适当的调整和优化,以确保双向数据绑定的正确性和稳定性。同时,深入理解 Vue 3 的响应式机制和组件通信原理,将有助于更好地运用 `v-model` 实现自定义组件的双向数据绑定。
|
25天前
|
缓存 监控 JavaScript
Vue.js 框架下的性能优化策略与实践
Vue.js 框架下的性能优化策略与实践
|
1月前
|
JavaScript 索引
Vue 3.x 版本中双向数据绑定的底层实现有哪些变化
从Vue 2.x的`Object.defineProperty`到Vue 3.x的`Proxy`,实现了更高效的数据劫持与响应式处理。`Proxy`不仅能够代理整个对象,动态响应属性的增删,还优化了嵌套对象的处理和依赖追踪,减少了不必要的视图更新,提升了性能。同时,Vue 3.x对数组的响应式处理也更加灵活,简化了开发流程。
|
25天前
|
JavaScript 前端开发 API
从Vue 2到Vue 3的演进
从Vue 2到Vue 3的演进
39 0
|
25天前
|
JavaScript 前端开发 API
Vue.js响应式原理深度解析:从Vue 2到Vue 3的演进
Vue.js响应式原理深度解析:从Vue 2到Vue 3的演进
54 0
下一篇
DataWorks