Cron 表达式相关知识详见:【实战】Linux基础知识必学 —— 定时任务
qnn-react-cron 可以看做 react-cron-antd 的升级版(具体“渊源”可见文档),现有功能如下:
直到现在作者依旧在维护(这篇文章之前最新库更新日期:2023.03.02)
- npm:https://www.npmjs.com/package/qnn-react-cron
- github: https://github.com/wangzongming/qnn-react-cron
.
yarn add qnn-react-cron | npm i qnn-react-cron
这一步遇到依赖不兼容问题可见后面内容:<三、常见问题及解决>
import React from "react"; import Cron from "qnn-react-cron";
啊哈,有点简单,这样只能显示,进行被隔离的操作,若要与页面其他组件联动,接着往下看。
import React, { useState } from "react"; import Cron from "qnn-react-cron"; export default () => { const [cronValue, setCronValue] = useState('') returncronValue} onOk={setCronValue} /> }
是 setCronValue(value)}/> 的简写
或是使用了表单(Form),比如需要将表达式赋值到 input 框中:
import React from "react"; import Cron from "qnn-react-cron"; export default () => { const { getFieldValue, setFieldsValue } = props.form returngetFieldValue('cronValue')} onOk={value => setFieldsValue({ cronValue: value})} /> }
这样点击 生成 按钮即可赋值到 input 框中,在 input 框中修改也能同步到组件中。
但是组件默认带了两个按钮:解析到UI、生成,要想隐藏 解析到UI 按钮只能将两个按钮全部都走自定义(有其他想要的功能,比如 重置 也能使用下面的自定义按钮):
import React, { useState } from "react"; import { Button } from "antd"; import Cron from "qnn-react-cron"; export default () => { const { getFieldValue, setFieldsValue } = props.form const [fns, setFns] = useState({}) returngetFieldValue('cronValue')} // 相当于 ref getCronFns={setFns} // 自定义底部按钮后需要自行调用方法来或者值 footer={[ //默认值 ]} /> }
若是组件用在模态框(Modal)中,组件和模态框在右下方都有按钮,可以隐藏默认按钮并将按钮功能(解析到UI、生成)提取到其他地方,比如输入框(Input)的右侧:
import Cron from "qnn-react-cron"; import { Form, Input, Button } from "antd" // import { useState } from "react"; const CronIndex = () => { // const [cronRef, setCronRef] = useState() let cronRef const [ form ] = Form.useForm() const { getFieldValue, setFieldsValue } = form return
此时效果:<输入框> 实时同步 到<组件>,<组件>中变化在点击生成按钮时同步到<输入框>,如图:
getCronFns 中对于 cronRef 值的获取不建议使用 useState(代码中有相关示例,已注释掉,感兴趣的可以尝试一下) ,会引起报错:Warning: Maximum update depth exceeded. This can happen when a component calls setState inside useEffect, but useEffect either doesn’t have a dependency array, or one of the dependencies changes on every render.
{ second: true, minute:true, hour: true, day: true, month:true, week:true, year:true, }} // 默认显示哪个面板, 默认为 second, 如果隐藏了 second 需要自行设置 defaultTab={"second"} />
隐藏秒,默认显示分钟的设置,如下:
{ second: false }} defaultTab={"minute"} />
默认值是:* * * * * ? *,因此在隐藏某个面板时,要做好对该部分隐藏值的处理
博主在记录这篇博文时,安装的版本是:qnn-react-cron@1.0.4,所支持主要依赖版本:
若是项目时用的还是比较老的 antd 版本,或是 react 版本高于 qnn-react-cron 所依赖版本在安装依赖时会发生如下报错:
npm ERR! code ERESOLVE npm ERR! ERESOLVE unable to resolve dependency tree npm ERR! npm ERR! While resolving: npm-test@0.1.0 npm ERR! Found: react@18.2.0 npm ERR! node_modules/react npm ERR! react@"^18.2.0" from the root project npm ERR! peer react@">=16.9.0" from antd@4.24.8 npm ERR! node_modules/antd npm ERR! peer antd@"^4.5.2" from qnn-react-cron@1.0.4 npm ERR! node_modules/qnn-react-cron npm ERR! qnn-react-cron@"*" from the root project npm ERR! 1 more (react-dom) npm ERR! npm ERR! Could not resolve dependency: npm ERR! peer react@"^15.0.0 || ^16.0.0 || ^17.0.0" from qnn-react-cron@1.0.4 npm ERR! node_modules/qnn-react-cron npm ERR! qnn-react-cron@"*" from the root project npm ERR! npm ERR! Fix the upstream dependency conflict, or retry npm ERR! this command with --force or --legacy-peer-deps npm ERR! to accept an incorrect (and potentially broken) dependency resolution. npm ERR! ...
不要慌,解决办法就在报错日志中(顺便学习英语了,嘻嘻):
- 原因:npm 7.x 之前的版本遇到依赖冲突会忽视依赖冲突,继续进行安装;npm 7.x 版本开始不会自动进行忽略,需要用户手动输入命令,两种选择:
- –force 无视冲突,强制获取远端npm库资源 (覆盖之前)
- –legacy-peer-deps 忽视依赖冲突,继续安装(不覆盖之前)
npm install vue-router --force 或者 npm install vue-router --legacy-peer-deps
参见:【已解决】Instance created by useForm is not connected to any Form element. Forget to pass form prop
Warning: Maximum update depth exceeded. This can happen when a component calls setState inside useEffect, but useEffect either doesn’t have a dependency array, or one of the dependencies changes on every render.
详见二.2.(3)案例或:博主在大佬提的issues下再次提问:https://github.com/wangzongming/qnn-react-cron/issues/21
- 搜索其他 vue cron 相关:https://www.npmjs.com/search?ranking=popularity&q=vue-cron
(排序条件:Optimal(匹配度);Popularity(受欢迎度);Quality(质量);Maintenance(维护时间))
over