灏天阁

vue3.2/Vite/Ts85: 角色管理模块的数据展示业务

· Yin灏

目录结构

└─src
    ├─api
    │  └─acl
    │      └─role
    │          ├─index.ts
    │          └─type.ts
    └─views
        └─acl
            └─role
                └─index.vue

角色管理模块

src/views/acl/role/index.vue

<template>
  <el-card>
    <el-form :inline="true" class="form">
      <el-form-item label="职位搜索">
        <el-input placeholder="请输入搜索职位的关键字" v-model="keyWord"></el-input>
      </el-from-item>
      <el-form-item>
        <el-button type="primary" size="default" :disabled="keyWord ? false : true" @click="search">搜索</el-button>
        <el-button type="primary" size="default" @click="reset">重置</el-button>
      </el-form-item>
    </el-from>
  </el-card>
  <el-card>
    <el-button type="primary" size="default" icon="Plus">添加职位</el-button>
    <el-table border :data="allRole">
      <el-table-column type="index" label="#" align="center"></el-table-column>
      <el-table-column label="ID" align="center" prop="id"></el-table-column>
      <el-table-column label="职位名称" align="center" show-overflow-tooltip prop="roleName"></el-table-column>
      <el-table-column label="创建时间" align="center" show-overflow-tooltip prop="createTime"></el-table-column>
      <el-table-column label="更新时间" align="center" show-overflow-tooltip prop="updateTime"></el-table-column>
      <el-table-column label="操作" align="center" width="280px">
        <template #="{row}">
          <el-button type="primary" size="small" icon="User">分配权限</el-button>
          <el-button type="primary" size="small" icon="Edit">编辑</el-button>
          <el-button type="primary" size="small" icon="Delete">删除</el-button>
        </template>
      </el-table-column>
    </el-table>
    <el-pagination
      v-model:current-page="pageNo"
      v-model:page-size="pageSize"
      :page-sizes="[10, 20, 30, 40]"
      :background="true"
      layout="prev, pager, next, jumper, -> , sizes, total"
      :total="total"
      @current-change="getHasRole"
      @size-change="sizeChange"
    ></el-pagination>
  </el-card>
</template>
<script setup lang="ts">
  import { ref, onMounted } from 'vue';
  import { reqAllRoleList } from '@/api/acl/role';
  import { RoleResponseData, Records } from '@/api/acl/role/type';

  import useLayOutSettingStore from "@/store/modules/setting";
  let settingStore = useLayOutSettingStore();

  let pageNo = ref<number>(1);
  let pageSize = ref<number>(10);
  let total = ref<number>(0);
  let keyWord = ref<string>('');
  let allRole = ref<Records>([]);

  const getHasRole = async (pager = 1) => {
    pageNo.value = pager;
    const result: RoleResponseData = await reqAllRoleList(pageNo.value, pageSize.value, keyWord.value);
    if(result.code === 200) {
      total.value = result.data.total;
      allRole.value = result.data.records;
    }
  }

  const sizeChange = () => {
    getHasRole()
  }

  const search = () => {
    getHasRole()
    keyWord.value = '';
  }

  const reset = () => {
    settingStore.refresh = !settingStore.refresh;
  };

  onMounted(() => {
    getHasRole()
  })
</script>
<style scoped>
  .form {
    display: flex;
    justify-content: space-between;
    align-items: center;
  }
</style>

接口处理

src/api/acl/role/index.ts

import request from "@/utils/request";
import type { RoleResponseData } from "./type";

enum API {
  ALLROLE_URL = "/admin/acl/role/",
}

export const reqAllRoleList = (page: number, limit: number, roleName: string) =>
  request.get<any, RoleResponseData>(
    API.ALLROLE_URL + `${page}/${list}?roleName=${roleName}`
  );

接口 TS 类型处理

src/api/acl/role/type.ts

export interface ResponseData {
  code: number;
  message: string;
  ok: boolean;
}
export interface RoleData {
  id?: number;
  createTime?: string;
  updateTime?: string;
  roleName: string;
  remark?: string;
}
export type Records = RoleData[];
export interface RoleResponseData extends ResponseData {
  data: {
    records: Records;
    total: number;
    size: number;
    current: number;
    orders: [];
    optimizeCountSql: boolean;
    hitCount: boolean;
    countId: null;
    maxLimit: null;
    searchCount: boolean;
    pages: number;
  };
}

- Book Lists -