当前位置:   article > 正文

用Vue做后台管理系统时常用的自定义校验_后台管理系统添加修改数据校验

后台管理系统添加修改数据校验

 场景:用Vue做后台管理系统时常用的自定义校验。对tree型数据中同级名称不能相同,编码不能重复进行自定义校验

  1. data() {
  2. const validCode = (rule, value, callback) => {
  3. // 添加时的校验:code不能重复
  4. let existCodeList = this.originList
  5. if (this.isEdit) {
  6. // 编辑时的校验: code能取自己
  7. existCodeList = this.originList.filter(item => item.id !== this.formData.id)
  8. }
  9. existCodeList.map(it => it.code).includes(value)
  10. ? callback(new Error(value + '已经占用'))
  11. : callback()
  12. }
  13. const validName = (rule, value, callback) => {
  14. // 添加时的校验: 名字不能取子元素的名字
  15. let existNameList = this.originList.filter(item => item.pid === this.formData.pid)
  16. if (this.isEdit) {
  17. // 编辑时的校验: 名字不能取兄弟(排除自己)的名字
  18. // 找兄弟,排除自己
  19. existNameList = this.originList.filter(item => item.pid === this.formData.pid && item.id !== this.formData.id)
  20. }
  21. existNameList.map(it => it.name).includes(value)
  22. ? callback(new Error(value + '已经占用'))
  23. : callback()
  24. }
  25. return {
  26. // 省略其他
  27. rules: {
  28. code: [{ message: '不能为空', required: true, trigger: 'blur' }, { validator: validCode, trigger: 'blur' }],
  29. name: [{ message: '不能为空', required: true, trigger: 'blur' }, { validator: validName, trigger: 'blur' }]
  30. },
  31. originList: [] // 在做校验时需要用到的数据
  32. }
  33. }

在数据加载成功之后,对originList做初始化。

  1. <script>
  2. async loadPermissionList() {
  3. try {
  4. const res = await getPermissionList()
  5. console.log('获取权限数据', res)
  6. + this.originList = res.data.map(({ id, pid, name, code }) => ({ id, pid, name: name.trim(), code }))
  7. this.list = tranListToTreeData(res.data)
  8. } catch (err) {
  9. console.log(err)
  10. }
  11. }
  12. </script>

name.trim()是为了清除后端返回的数据中的空格

  1. <!-- 表单内容 -->
  2. <el-form
  3. ref="form"
  4. :model="formData"
  5. + :rules="rules"
  6. label-width="100px"
  7. >
  8. <el-form-item label="权限名称"
  9. + prop="name">
  10. + <el-input v-model.trim="formData.name" />
  11. </el-form-item>
  12. <el-form-item label="权限标识"
  13. + prop="code">
  14. + <el-input v-model.trim="formData.code" />
  15. </el-form-item>

 使用校验时给表单添加 :rules="rules",给要校验的添加prop,做兜底校验要用到ref

  1. onSubmit() {
  2. this.$refs.form.validate(valid => {
  3. if (valid) {
  4. this.isEdit ? this.doEdit() : this.doAdd()
  5. }
  6. })

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/Gausst松鼠会/article/detail/227794
推荐阅读
相关标签
  

闽ICP备14008679号