灏天阁

vue3.2/Vite/Ts86: 添加角色静态搭建

· Yin灏

目录结构

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

对应接口处理

src/api/acl/role/index.ts

import type { RoleData } from "./type";
//...
enum API {
  ADDROLE_URL = "/admin/acl/role/save",
  UPDATEROLE_URL = "/admin/acl/role/update",
}
//...
export const reqAddOrUpdateRole = (data: RoleData) => {
  if (data.id) {
    return request.put<any, any>(API.UPDATEROLE_URL, data);
  } else {
    return request.post<any, any>(API.ADDROLE_URL, data);
  }
};

添加新职位

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" @click="addRole">添加职位</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" @click="updateRole(row)">编辑</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>
  <!-- 添加与更新职位 -->
  <el-dialog v-model="dialogVisible" title="添加职位">
    <el-form>
      <el-form-item label="职位名称">
        <el-input placeholder="请输入职位名称"></el-input>
      </el-form-item>
    </el-form>
    <template #footer>
      <el-button type="primary" size="default" @click="dialogVisible = false">取消</el-button>
      <el-button type="primary" size="default">确定</el-button>
    </template>
  </el-dialog>
</template>
<script setup lang="ts">
  import { ref, onMounted } from 'vue';
  import { reqAllRoleList, reqAddOrUpdateRole } from '@/api/acl/role';
  import { RoleResponseData, Records, RoleData } 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>([]);
  let dialogVisible = ref<boolean>(false);

  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;
  };

  const addRole = () => {
    dialogVisible.value = true;
  }

  const updateRole = (row: RoleData) => {
    dialogVisible.value = true;
  }

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

- Book Lists -