首页 > 其他分享 >departments/components/add.vue

departments/components/add.vue

时间:2022-11-12 09:34:54浏览次数:2932  
标签:vue string form 部门 item add components message true

<template>
  <!-- 组件v-model
        xxx   v-model='abc'  :value="abc"  @input="abc=$event"
        xxx组件内
           props:{
            abc:{
                required:true,
            }
           }
           this.$emit('input',实参值)
   -->

  <!-- 部门负责人:
          1:定义api
          2:导入api
          3:点击select时调用api获取数据存储
          4:渲染
    -->

  <!--   基本表单验证
          1:表单元素值的绑定
          2:el-form
                 model
                 rules:{
                    prop的值:[
                     {required:true,message:错误信息,trigger:'change/blur'},
                     {min,max,message:错误信息,trigger:'change/blur'},
                     {pattern:正则,message:错误信息,trigger:'change/blur'}
                    ]
                 }
          3:el-form-item
                 prop

       全局验证
          1:基本验证已ok
          2:el-form  ref="form"
          3:this.$refs.form.validate((result)=>{
            result:true验证通过
                   false:验证失败
          })
 -->

  <el-dialog
    :title="{ add: '新增部门', edit: '编辑部门' }[mode]"
    width="600px"
    :visible.sync="isShow"
    @close="closeEvent"
  >
    <el-form ref="form" label-width="100px" :model="form" :rules="rules">
      <el-form-item prop="name" label="部门名称">
        <el-input v-model.trim="form.name" placeholder="1-50个字符" />
      </el-form-item>
      <el-form-item prop="code" label="部门编码">
        <el-input v-model.trim="form.code" placeholder="1-50个字符" />
      </el-form-item>
      <el-form-item prop="manager" label="部门负责人">
        <el-select
          v-model="form.manager"
          placeholder="选择部门负责人"
          @focus="focusEvent"
        >
          <el-option
            v-for="item in userList"
            :key="item.id"
            :label="item.username"
            :value="item.username"
          />
        </el-select>
      </el-form-item>
      <el-form-item prop="introduce" label="部门介绍">
        <el-input
          v-model="form.introduce"
          placeholder="1-300个字符"
          type="textarea"
          :rows="4"
        />
      </el-form-item>
    </el-form>
    <template #footer>
      <div style="text-align: center">
        <el-button @click="isShow = false">取消</el-button>
        <el-button type="primary" @click="submit">确定</el-button>
      </div>
    </template>
  </el-dialog>
</template>
<script>
import {
  sysUserSimple,
  companyDepartmentPost,
  companyDepartmentPut
} from '@/api/departments'
export default {
  props: {
    initList: {
      required: true,
      type: Array
    }
  },
  data() {
    return {
      isShow: false,
      mode: 'add', // add:新增  edit:编辑
      userList: [],
      form: {
        name: '', //	string	非必须		部门名称
        code: '', //	string	非必须		部门编码,同级部门不可重复
        manager: '', //	string	非必须		负责人名称
        introduce: '', //	string	非必须		介绍
        pid: '' //	string	非必须		父级部门ID
      },
      rules: {
        name: [
          { required: true, message: '必填', trigger: 'change' },
          { min: 1, max: 50, message: '请输入1-50个字符', trigger: 'change' },
          {
            validator: (rule, value, callback) => {
              let arr = []
              if (this.mode === 'add') {
                // 1:找出点击项的子集部门
                arr = this.initList.filter((item) => item.pid === this.form.pid) // [{name:'人事部'}...]
                // 2:验证输入的部门名称在子集部门中不存在
              } else if (this.mode === 'edit') {
                // 1:找出自己的同级部门,同级部门特点:pid值相同,排除自己
                arr = this.initList.filter(
                  (item) =>
                    item.pid === this.form.pid && item.id !== this.form.id
                )
                // 验证是否重名
              }
              const bol = arr.every((item) => value !== item.name)
              bol ? callback() : callback(new Error('部门名称已存在'))
            }
          }
        ], //	string	非必须		部门名称
        code: [
          { required: true, message: '必填', trigger: 'change' },
          { min: 1, max: 50, message: '请输入1-50个字符', trigger: 'change' },
          {
            // 新增表单验证

            // 部门编码不可重名:
            // 原始的所有部门的数据   this.initList= [{code:'1'}...]
            // 当前项是  value
            validator: (rule, value, callback) => {
              let bol = false
              if (this.mode === 'add') {
                // find:返回值,找到是相应项的数据  找不到:undefined
                // every   some
                // every:所有项都符合条件才是true
                // some:只要有一个项满足条件就是true
                // const bol = this.initList.every((item) => {
                //   if (item.code !== value) {
                //     return true
                //   }
                //   return false
                // })
                bol = this.initList.every((item) => item.code !== value)
              } else if (this.mode === 'edit') {
                // 先过滤掉自身
                const newArr = this.initList.filter(
                  (item) => item.id !== this.form.id
                )
                // 再来判断是否重复
                bol = newArr.every((item) => item.code !== value)
              }
              bol ? callback() : callback(new Error('部门编码重复'))
            },
            trigger: 'change'
          }
        ], //	string	非必须		部门编码,同级部门不可重复
        manager: [{ required: true, message: '必填', trigger: 'change' }], //	string	非必须		负责人名称
        introduce: [
          { required: true, message: '必填', trigger: 'change' },
          { min: 1, max: 300, message: '请输入1-300个字符', trigger: 'change' }
        ] //	string	非必须		介绍
      }
    }
  },
  methods: {
    // 获取员工列表
    async focusEvent() {
      if (this.userList.length === 0) {
        const res = await sysUserSimple()
        this.userList = res.data
        console.log(res)
      }
    },
    // 确定点击
    submit() {
      this.$refs.form.validate(async(result) => {
        if (result) {
          if (this.mode === 'add') {
            await companyDepartmentPost(this.form)
            // 调用成功  1:清空表单数据与验证  2:关闭弹框  3:刷新父级列表数据 4:提示
            this.$message.success('添加成功')
          } else if (this.mode === 'edit') {
            await companyDepartmentPut(this.form)
            this.$message.success('编辑成功')
          }
          this.isShow = false
          this.$emit('getData')
        }
        console.log(result)
      })
    },
    // 关闭时事件
    closeEvent() {
      this.$refs.form.resetFields()
      this.form = {
        name: '', //	string	非必须		部门名称
        code: '', //	string	非必须		部门编码,同级部门不可重复
        manager: '', //	string	非必须		负责人名称
        introduce: '', //	string	非必须		介绍
        pid: '' //	string	非必须		父级部门ID
      }
    }
  }
}
</script>
<style></style>


标签:vue,string,form,部门,item,add,components,message,true
From: https://www.cnblogs.com/strundent/p/16882705.html

相关文章

  • departments/index.vue
    <template><!--查:1:定义api2:导入api3:进入页面就调用api获取数据并存储4:渲染数据增:1:创建一个弹框组件2:导入注册使用3:点击新......
  • #yyds干货盘点#Vue中的父子组件之间的数据传递之props、$ref和$emit
    props是用于父组件向子组件传递数据信息props是单向绑定的,即只能父组件向子组件传递,不能反向。<!--父组件--><template><div><h1>我是父组件!</h1><c......
  • VUE3+Element Plus的el-input获取焦点
    <template><el-inputv-model="msg"id="inputbox"type="text"style="width:500px"/><el-button@click="handleGetFocus">获取焦点</el-button></tem......
  • CF1252K Addition Robot 题解
    题目链接思路对于\(A=A+B\),\(B=A+B\)这种的递推式可以考虑矩阵加速递推,可得:\[\left(\begin{matrix}A+B&B\end{matrix}\right)=\left(\begin{ma......
  • vuejs实现很多照片组成爱心样式
    vuejs实现很多照片组成爱心样式链接:https://pan.baidu.com/s/1GrnFwY0Kotz3-2dT9X8oTA?pwd=0011提取码:0011 ......
  • 【工具】5 个可以加速开发的 VueUse 库函数
    英文| https://learnvue.co/2021/07/5-vueuse-library-functions-that-can-speed-up-development/翻译|小爱VueUse是AnthonyFu的一个开源项目,它为Vue开发人员提供......
  • 【Vuejs】1000- 一步一步实现 Vue 3 Reactivity
    Vue3中的响应式原理可谓是非常之重要,通过学习Vue3的响应式原理,不仅能让我们学习到Vue.js的一些设计模式和思想,还能「帮助我们提高项目开发效率和代码调试能力」。在这......
  • 2. 说一下vue2和vue3的区别 ?
    1.vue3使用proxy替换Object.defineProperty实现数据响应式,所以vue3的性能得到了提升;2.vue3使用组合式API替代了vue2中的选项式API ;3.vue3......
  • vue框架跨域请求之axios
    1、打开hbuilderx,【文件】==》【新建】==》【项目】,创建vue项目。   2、创建后的vue项目结构如下所示,打开【package.json】配置文件,添加axios相关依赖。   ......
  • VueRouter笔记 - 路由守卫
    路由守卫目录路由守卫1.路由守卫简介2.全局前置守卫3.全局后置路由守卫4.独享路由守卫5.组件内路由守卫1.路由守卫简介路由守卫主要用来通过跳转或取消的方式守......