vue3+ts后台管理系统

<template>

  <div class="modal">

    <el-dialog

      v-model="dialogVisible"

      :title="isNewRef ? '新建用户' : '编辑用户'"

      width="30%"

      center

    >

      <div class="form">

        <el-form :model="formData" label-width="80px" size="large">

          <el-form-item label="用户名" prop="name">

            <el-input v-model="formData.name" placeholder="请输入用户名" />

          </el-form-item>

          <el-form-item label="真实姓名" prop="realname">

            <el-input

              v-model="formData.realname"

              placeholder="请输入真实姓名"

            />

          </el-form-item>

          <el-form-item v-if="isNewRef" label="密码" prop="password">

            <el-input

              v-model="formData.password"

              placeholder="请输入密码"

              show-password

            />

          </el-form-item>

          <el-form-item label="手机号码" prop="cellphone">

            <el-input

              v-model="formData.cellphone"

              placeholder="请输入手机号码"

            />

          </el-form-item>

          <el-form-item label="选择角色" prop="roleId">

            <el-select

              v-model="formData.roleId"

              placeholder="请选择角色"

              style="width: 100%"

            >

              <template v-for="item in entireRoles" :key="item.id">

                <el-option :label="item.name" :value="item.id" />

              </template>

            </el-select>

          </el-form-item>

          <el-form-item label="选择部门" prop="departmentId">

            <el-select

              v-model="formData.departmentId"

              placeholder="请选择部门"

              style="width: 100%"

            >

              <template v-for="item in entireDepartments" :key="item.id">

                <el-option :label="item.name" :value="item.id" />

              </template>

            </el-select>

          </el-form-item>

        </el-form>

      </div>

      <template #footer>

        <span class="dialog-footer">

          <el-button @click="dialogVisib

le = false">取消</el-button>

          <el-button type="prim

      <el-button type="primary" @click="handleConfirmClick">

            确定

          </el-button>

        </span>

      </template>

    </el-dialog>

  </div>

</template>

 

<script setup lang="ts">

import { reactive, ref } from 'vue'

import useMainStore from '@/store/main/main'

import { storeToRefs } from 'pinia'

import useSystemStore from '@/store/main/system/system'

 

// 1.定义内部的属性

const dialogVisible = ref(false)

const formData = reactive<any>({

  name: '',

  realname: '',

  password: '',

  cellphone: '',

  roleId: '',

  departmentId: ''

})

const isNewRef = ref(true)

const editData = ref()

 

// 2.获取roles/departments数据

const mainStore = useMainStore()

const systemStore = useSystemStore()

const { entireRoles, entireDepartments } = storeToRefs(mainStore)

 

// 2.定义设置dialogVisible方法

function setModalVisible(isNew: boolean = true, itemData?: any) {

  dialogVisible.value = true

  isNewRef.value = isNew

  if (!isNew && itemData) {

    // 编辑数据

    for (const key in formData) {

      formData[key] = itemData[key]

    }

    editData.value = itemData

  } else {

    // 新建数据

    for (const key in formData) {

      formData[key] = ''

    }

    editData.value = null

  }

}

 

// 3.点击了确定的逻辑

function handleConfirmClick() {

  dialogVisible.value = false

  if (!isNewRef.value && editData.value) {

    // 编辑用户的数据

    systemStore.editUserDataAction(editData.value.id, formData)

  } else {

    // 创建新的用户

    systemStore.newUserDataAction(formData)

  }

}

 

// 暴露的属性和方法

defineExpose({ setModalVisible })

</script>

 

<style lang="less" scoped>

.form {

  padding: 0 20px;

}

</style>

 

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值