• 前端Vue3+element-plus表单输入框实现Cron表达式校验


    页面如下:

    本来想手写正则表达式校验,结果发现很麻烦,cron表达式组成如下:

    开发使用框架为vue3+element-plus,于是选择cron-validator依赖。使用步骤如下:

    1、通过npm install cron-validator命令安装:

    2、可以通过package.json文件中看到,已安装成功。

    3、在你需要校验的组件中,通过import { isValidCron } from 'cron-validator'导入依赖:

    4、使用,上一步从’cron-validator’导入{ isValidCron },就可以使用isValidCron('* * * * *')进行判断,返回boolean类型默认不支持秒和年字段,因为这两个字段在 cron 表达式中较为不常见:

    1. if (isValidCron('* * * * *')) {
    2. // Do something
    3. }

    5、但是由于用户的使用习惯不同,你可能需要开启其他的配置,比如需要支持秒,那就需要设置seconds为true来开启支持,如果设置为false,则保持不支持。下面代码中,列举了四个其他开启配置项,可通过阅读代码中的注释部分来理解。

    1. const rules = reactive<FormRules<RuleForm>>({
    2. ...
    3. cronExpression: [
    4. { required: true, message: '请输入Cron表达式', trigger: 'blur' },
    5. {
    6. validator: (rule, value, callback) => {
    7. // seconds可以通过seconds在选项中将标志传递为 true来启用对秒的支持(例:* * * * * *);
    8. // alias启用alias对月份和工作日的支持(例:* * * * mon);
    9. // allowBlankDay可以启用该标志以使用?符号将天或工作日标记为空白(例:* * * * ?);
    10. // allowSevenAsSunday可以启用该标志以支持数字 7 作为星期日(例:* * * * 7);
    11. const isOk = isValidCron(value, {
    12. seconds: true,
    13. alias: true,
    14. allowBlankDay: true,
    15. allowSevenAsSunday: true
    16. });
    17. if (!isOk) {
    18. callback(new Error('请输入可用的Cron表达式'));
    19. } else {
    20. callback();
    21. }
    22. },
    23. trigger: 'blur',
    24. },
    25. ]
    26. })

  • 相关阅读:
    从源码看vue(v2.7.10)中的v-bind的原理
    Nginx学习笔记12——Nginx高可用和keepalived
    Python读写文件
    冲击继电器JC-7/11/DC110V
    php社区果蔬网站毕业设计源码211548
    移植freertos到qemu上运行
    数据结构28TI
    [附源码]计算机毕业设计springboot创新创业管理系统
    Golang 中空的切片转化成 JSON 后变为 null 的问题如何解决?
    petalinux下修改系统空间笔记
  • 原文地址:https://blog.csdn.net/wdm891026/article/details/133136874