灏天阁

vue3.2/Vite/Ts87: 添加与更新角色业务

· Yin灏

目录结构

└─src
    └─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" @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="RoleParams.id ? '更新职位' : '添加职位'">
    <el-form :model="RoleParams" :rules="rules" ref="form">
      <el-form-item label="职位名称" prop="roleName">
        <el-input placeholder="请输入职位名称" v-model="RoleParams.roleName"></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" @click="save">确定</el-button>
    </template>
  </el-dialog>
</template>
<script setup lang="ts">
  import { ref, onMounted, reactive, nextTick } from 'vue';
  import { reqAllRoleList, reqAddOrUpdateRole, 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);

  let form = ref<any>();

  let RoleParams = reactive<RoleData>({
    roleName: '',
  })

  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;
    Object.assign(RoleParams, {
      roleName: '',
      id: ''
    });
    nextTick(() => {
      form.value.clearValidate('roleName')
    })
  }

  const updateRole = (row: RoleData) => {
    dialogVisible.value = true;
    Object.assign(RoleParams, row);
    nextTick(() => {
      form.value.clearValidate('roleName')
    })
  }

  const validatorRoleName = (rule: any, value: any, callBack: any) => {
    if(value.trim().length >= 2) {
      callBack()
    } else {
      callBack(new Error('职位名称至少为两位'))
    }
  }

  const rules = {
    roleName: [
      {
        required: true, trigger: 'blur', validator: validatorRoleName
      }
    ]
  }

  const save = async () => {
    await form.value.validate()
    const result: any = await reqAddOrUpdateRole(RoleParams);
    if(result.code === 200) {
      ElMessage({
        type: 'success',
        message: RoleParams.id ? '更新成功' : '添加成功'
      })
      dialogVisible.value = false;
      getHasRole(RoleParams.id ? pageNo.value : 1)
    } else {
      ElMessage({
        type: 'error',
        message: RoleParams.id ? '更新失败' : '添加失败'
      })
    }
  }

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

- Book Lists -