• element 表单自定义效验规则


    效验规则js

    1. let matching = (value, callback, reg, message) => {
    2. if (value === "" || value === undefined || value == null) {
    3. callback(new Error(message));
    4. } else {
    5. if (!reg.test(value)) {
    6. callback(new Error(message));
    7. } else {
    8. callback();
    9. }
    10. }
    11. };
    12. module.exports = {
    13. USCCode(rule, value, callback) {
    14. let reg = /^[^_IOZSVa-z\W]{2}\d{6}[^_IOZSVa-z\W]{10}$/;
    15. matching(value, callback, reg, "请输入正确的18位统一社会信用代码");
    16. },
    17. zero(rule, value, callback) {
    18. let reg = /^([1-9]\d*|[0]{1,1})$/;
    19. matching(value, callback, reg, "请输入大于等于零的数字");
    20. },
    21. Username(rule, value, callback) {
    22. let reg = /^(?![0-9]*$)(?![a-zA-Z]*$)[a-zA-Z0-9]{6,12}$/;
    23. matching(value, callback, reg, "请输入6-12位字母和数字组合");
    24. },
    25. SimplePwd(rule, value, callback) {
    26. let reg = /^[_a-zA-Z0-9]+$/;
    27. matching(value, callback, reg, "包含英文字母、数字及下划线组成");
    28. },
    29. ComplexPwd(rule, value, callback) {
    30. let reg =
    31. /^(?![\d]+$)(?![a-zA-Z]+$)(?![^\da-zA-Z]+$)([^\u4e00-\u9fa5\s]){8,20}$/;
    32. matching(value, callback, reg, "请输入8-20位英文字母、数字或者符号");
    33. },
    34. Phone(rule, value, callback) {
    35. let reg = /^[1][3, 4, 5, 6, 7, 8][0-9]{9}$/;
    36. matching(value, callback, reg, "请输入正确的手机");
    37. },
    38. Email(rule, value, callback) {
    39. let reg = /^([a-zA-Z0-9]+[-_\.]?)+@[a-zA-Z0-9]+\.[a-z]+$/;
    40. matching(value, callback, reg, "输入正确的邮箱");
    41. },
    42. IdCard(rule, value, callback) {
    43. let reg = /(^\d{15}$)|(^\d{18}$)|(^\d{17}(\d|X|x)$)/;
    44. matching(value, callback, reg, "输入正确的身份证号码");
    45. },
    46. Company(rule, value, callback) {
    47. let reg = /^[A-Z0-9]{8}-[A-Z0-9]$|^[A-Z0-9]{8}-[A-Z0-9]-[0-9]{2}$/;
    48. matching(value, callback, reg, "请输入正确的营业执照");
    49. },
    50. Weixin(rule, value, callback) {
    51. let reg = /^[a-zA-Z][a-zA-Z0-9_-]{5,19}$/;
    52. matching(value, callback, reg, "请输入正确的微信号");
    53. },
    54. Integer(rule, value, callback) {
    55. let reg = /^[1-9][0-9]*$/;
    56. matching(value, callback, reg, "请输入正确的整数");
    57. },
    58. Number(rule, value, callback) {
    59. let reg = /^\d+$|^\d+[.]?\d+$/;
    60. matching(value, callback, reg, "请输入纯数字");
    61. },
    62. Landline(rule, value, callback) {
    63. let reg = /^(\d{3,4}-)?\d{7,8}$/;
    64. matching(value, callback, reg, "请输入正确的座机");
    65. },
    66. Ip(rule, value, callback) {
    67. let reg =
    68. /^(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])\.(\d{1,2}|1\d\d|2[0-4]\d|25[0-5])$/;
    69. matching(value, callback, reg, "请输入正确的IP");
    70. },
    71. Price(rule, value, callback) {
    72. let reg = /^-?\d{1,4}(?:\.\d{1,2})?$ /;
    73. matching(value, callback, reg, "请输入正确的价格");
    74. },
    75. BankCard(rule, value, callback) {
    76. let reg = /^([1-9]{1})(\d{14}|\d{18})$/
    77. matching(value, callback, reg, '请输入正确的银行卡')
    78. },
    79. Hundred(rule, value, callback) {
    80. let reg = /^(?:[1-9]?\d|100)$/
    81. matching(value, callback, reg, '请输入0~100之间的数字')
    82. }
    83. }

    表单引用

    1. rules: {
    2. reportEmail: [
    3. { required: true, validator: verification.Email, trigger: "blur" },
    4. ],
    5. },

  • 相关阅读:
    学习笔记丨Shell
    【历史上的今天】6 月 24 日:网易成立;首届消费电子展召开;世界上第一次网络直播
    mybatis-plus多数据源配置
    访问seafile网页端显示502 Bad Gateway
    计算机毕业设计Java爱家家政公司网站(源码+系统+mysql数据库+lw文档)
    APS排程软件与ERP、MES的集成方式
    非最小相位系统的闭环频域辨识算法
    解决Qt 构建项目时报错找不到serialport模块
    【机器学习】从理论到实践:决策树算法在机器学习中的应用与实现
    css一个图片上面加上遮罩蒙板,只修改img的样式不多写标签
  • 原文地址:https://blog.csdn.net/irisMoon06/article/details/133852512