位置: IT常识 - 正文

【实战】React 必会第三方插件 —— Cron 表达式生成器(qnn-react-cron)(react by)

编辑:rootadmin
【实战】React 必会第三方插件 —— Cron 表达式生成器(qnn-react-cron) 文章目录一、引子二、配置使用1.安装2.使用(1)直接调用(2)赋值到表单(Form)(3)自定义功能按钮(4)隐藏指定 Tab(5)其他三、常见问题及解决1.兼容低版本 antd 或高版本 react2.useForm 相关报错3.setState inside useEffect 死循环四、拓展学习1.cron表达式翻译 —— cronstrue2.其他 cron 相关 npm 库(包含 vue 相关)react-cron-generatorvue:vcrontabvue-cron-23.在线工具一、引子

推荐整理分享【实战】React 必会第三方插件 —— Cron 表达式生成器(qnn-react-cron)(react by),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:reacty,reacts,reacty,reactne,reactne,reactne,reacturn,reactiobs,内容如对您有帮助,希望把文章链接给更多的朋友!

Cron 表达式相关知识详见:【实战】Linux基础知识必学 —— 定时任务

qnn-react-cron 可以看做 react-cron-antd 的升级版(具体“渊源”可见文档),现有功能如下:

🎉 全面支持 cron:秒、分、时、日、月、周、年🎉 日及周条件互斥,自动改变响应值🎉 支持反解析 cron 表达式到 UI🎉 可结合此组件与 Antd 的下拉及输入组件封装成下拉输入框🎉 国际化支持🎉 TypeScript 支持

直到现在作者依旧在维护(这篇文章之前最新库更新日期:2023.03.02)

npm:https://www.npmjs.com/package/qnn-react-crongithub: https://github.com/wangzongming/qnn-react-cron .

二、配置使用1.安装yarn add qnn-react-cron | npm i qnn-react-cron

这一步遇到依赖不兼容问题可见后面内容:<三、常见问题及解决>

2.使用引用:import React from "react";import Cron from "qnn-react-cron";(1)直接调用<Cron />

啊哈,有点简单,这样只能显示,进行被隔离的操作,若要与页面其他组件联动,接着往下看。

默认生成表达式并赋值到变量:import React, { useState } from "react";import Cron from "qnn-react-cron";export default () => {const [cronValue, setCronValue] = useState('')return <Cronvalue={cronValue}onOk={setCronValue}/>}

<Cron onOk={setCronValue}/> 是 <Cron onOk={value => setCronValue(value)}/> 的简写

(2)赋值到表单(Form)

或是使用了表单(Form),比如需要将表达式赋值到 input 框中:

import React from "react";import Cron from "qnn-react-cron";export default () => {const { getFieldValue, setFieldsValue } = props.formreturn <Cronvalue={getFieldValue('cronValue')}onOk={value => setFieldsValue({ cronValue: value})}/>}

这样点击 生成 按钮即可赋值到 input 框中,在 input 框中修改也能同步到组件中。

(3)自定义功能按钮【实战】React 必会第三方插件 —— Cron 表达式生成器(qnn-react-cron)(react by)

但是组件默认带了两个按钮:解析到UI、生成,要想隐藏 解析到UI 按钮只能将两个按钮全部都走自定义(有其他想要的功能,比如 重置 也能使用下面的自定义按钮):

import React, { useState } from "react";import { Button } from "antd";import Cron from "qnn-react-cron";export default () => {const { getFieldValue, setFieldsValue } = props.formconst [fns, setFns] = useState({})return <Cronvalue={getFieldValue('cronValue')}// 相当于 ref getCronFns={setFns}// 自定义底部按钮后需要自行调用方法来或者值 footer={[ //默认值 <Button style={{ marginRight: 10 }} onClick={()=>fns.onParse()}>解析到UI</Button> <Button type="primary" onClick={()=>setFieldsValue({ cronValue: fns.getValue()}))}>生成</Button> ]}/>}

若是组件用在模态框(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 <Form form={form}> <Form.Item label="任务周期" name="cronValue"> <Input addonAfter={( <Button type='primary' style={{ margin: '-1px -12px', border: 'none' }} onClick={() => setFieldsValue({ cronValue: cronRef.getValue() })}>生成</Button> )}/> </Form.Item> <Cron value={getFieldValue('cronValue')} getCronFns={fns => cronRef = fns} // getCronFns={setCronRef} footer={[]} /> </Form>}export default CronIndex

此时效果:<输入框> 实时同步 到<组件>,<组件>中变化在点击生成按钮时同步到<输入框>,如图:

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.

(4)隐藏指定 Tab配置面板的隐藏与显示,默认如下:<Cron // 配置面板的隐藏, false 即隐藏 panesShow={{ second: true, minute:true, hour: true, day: true, month:true, week:true, year:true, }} // 默认显示哪个面板, 默认为 second, 如果隐藏了 second 需要自行设置 defaultTab={"second"}/>

隐藏秒,默认显示分钟的设置,如下:

<Cron panesShow={{ second: false }} defaultTab={"minute"} />

默认值是:* * * * * ? *,因此在隐藏某个面板时,要做好对该部分隐藏值的处理

(5)其他博主这里没有用到<语言国际化配置>,如有需要请参考文末官方文档三、常见问题及解决1.兼容低版本 antd 或高版本 react

博主在记录这篇博文时,安装的版本是:qnn-react-cron@1.0.4,所支持主要依赖版本:

antd@“^4.5.2”react@“^15.0.0 || ^16.0.0 || ^17.0.0”

若是项目时用的还是比较老的 antd 版本,或是 react 版本高于 qnn-react-cron 所依赖版本在安装依赖时会发生如下报错:

npm ERR! code ERESOLVEnpm ERR! ERESOLVE unable to resolve dependency treenpm ERR! npm ERR! While resolving: npm-test@0.1.0npm ERR! Found: react@18.2.0npm ERR! node_modules/reactnpm ERR! react@"^18.2.0" from the root projectnpm ERR! peer react@">=16.9.0" from antd@4.24.8 npm ERR! node_modules/antdnpm ERR! peer antd@"^4.5.2" from qnn-react-cron@1.0.4npm ERR! node_modules/qnn-react-cronnpm 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.4npm ERR! node_modules/qnn-react-cronnpm ERR! qnn-react-cron@"*" from the root projectnpm ERR!npm ERR! Fix the upstream dependency conflict, or retrynpm ERR! this command with --force or --legacy-peer-depsnpm ERR! to accept an incorrect (and potentially broken) dependency resolution.npm ERR!...

不要慌,解决办法就在报错日志中(顺便学习英语了,嘻嘻):

关键词:peer(匹配的,对等的);关键句:Fix the upstream dependency conflict, or retry(修复上游依赖冲突,或重试)原因:npm 7.x 之前的版本遇到依赖冲突会忽视依赖冲突,继续进行安装;npm 7.x 版本开始不会自动进行忽略,需要用户手动输入命令,两种选择:–force 无视冲突,强制获取远端npm库资源 (覆盖之前)–legacy-peer-deps 忽视依赖冲突,继续安装(不覆盖之前)npm install vue-router --force或者npm install vue-router --legacy-peer-deps2.useForm 相关报错

参见:【已解决】Instance created by useForm is not connected to any Form element. Forget to pass form prop

3.setState inside useEffect 死循环

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

四、拓展学习1.cron表达式翻译 —— cronstruenpm:https://www.npmjs.com/package/cronstrue2.其他 cron 相关 npm 库(包含 vue 相关)react-cron-generatornpm:https://www.npmjs.com/package/react-cron-generatordemo:https://sojinantony01.github.io/react-cron-generator/ vue:vcrontabnpm:https://www.npmjs.com/package/vcrontabdemo:https://small-stone.github.io/vCrontab/dist/ vue-cron-2npm:https://www.npmjs.com/package/vue-cron-2demo:https://1615450788.github.io/vue-cron/dist/index搜索其他 vue cron 相关:https://www.npmjs.com/search?ranking=popularity&q=vue-cron (排序条件:Optimal(匹配度);Popularity(受欢迎度);Quality(质量);Maintenance(维护时间))3.在线工具quartz/Cron/Crontab表达式在线生成工具-BeJSON.com在线Cron表达式生成器(pppet)在线Cron表达式生成器(qqe2)npm:qnn-react-cron - npm

over

本文链接地址:https://www.jiuchutong.com/zhishi/292293.html 转载请保留说明!

上一篇:图像质量评价指标metrics:PSNR 、SSIM、LPIPS(图像质量评价指标及方法 图像工程)

下一篇:半穹顶景观点上空的银河,优胜美地国家公园,加利福尼亚州 (© Cory Marshall/Tandem Stills + Motion)(穹顶高度)

  • 48v20ah等于多少毫安(48v20ah等于多少度)

    48v20ah等于多少毫安(48v20ah等于多少度)

  • 分辨率72dpi什么意思(分辨率72px什么意思)

    分辨率72dpi什么意思(分辨率72px什么意思)

  • 抖音为什么同步不了火山(抖音为什么同步才能评论)

    抖音为什么同步不了火山(抖音为什么同步才能评论)

  • 相机m是什么意思(相机m是什么意思手机)

    相机m是什么意思(相机m是什么意思手机)

  • 华为日历自动横屏(华为日历横线)

    华为日历自动横屏(华为日历横线)

  • 快手实名认证有什么用(快手实名认证有风险怎么办)

    快手实名认证有什么用(快手实名认证有风险怎么办)

  • 刚下的软件停止运行了(软件下载后显示停止运行)

    刚下的软件停止运行了(软件下载后显示停止运行)

  • 手机爱奇艺下载的视频在哪里(手机爱奇艺下载的电影怎么保存到U盘)

    手机爱奇艺下载的视频在哪里(手机爱奇艺下载的电影怎么保存到U盘)

  • 微信好友不显示来源(微信好友不显示该聊天是什么意思)

    微信好友不显示来源(微信好友不显示该聊天是什么意思)

  • 华为子公司都有哪些(华为子公司有多少家)

    华为子公司都有哪些(华为子公司有多少家)

  • vivo禁止安装怎么解除(vivoapp禁止安装)

    vivo禁止安装怎么解除(vivoapp禁止安装)

  • 红外线的应用有哪些(红外线常见的应用是)

    红外线的应用有哪些(红外线常见的应用是)

  • 华为nova6支不支持红外功能(华为nova6支不支持扩展卡)

    华为nova6支不支持红外功能(华为nova6支不支持扩展卡)

  • a57是不是全网通(a53全网通)

    a57是不是全网通(a53全网通)

  • 微信公众号每天只能发一篇文章吗(微信公众号每天只能群发一次吗)

    微信公众号每天只能发一篇文章吗(微信公众号每天只能群发一次吗)

  • 小米手机上hd是什么意思啊(小米手机上面hd)

    小米手机上hd是什么意思啊(小米手机上面hd)

  • 苹果耳机坏了一年内是免费更换吗(苹果耳机坏了一边小妙招)

    苹果耳机坏了一年内是免费更换吗(苹果耳机坏了一边小妙招)

  • 信号hd是什么意思(信号hd是什么意思,怎么关闭)

    信号hd是什么意思(信号hd是什么意思,怎么关闭)

  • iphone11多少美元(苹果11美国现在多少钱)

    iphone11多少美元(苹果11美国现在多少钱)

  • 手机怎么把文字做成文件(手机怎么把文字转换成文档)

    手机怎么把文字做成文件(手机怎么把文字转换成文档)

  • 微爱解除关系后还能恢复吗(微爱解除关系后对方知道吗)

    微爱解除关系后还能恢复吗(微爱解除关系后对方知道吗)

  • 咸鱼的评价可以删除吗(咸鱼的评价可以在淘宝上显示吗)

    咸鱼的评价可以删除吗(咸鱼的评价可以在淘宝上显示吗)

  • qq好友被删了怎么恢复(qq好友被删了怎么辅助验证)

    qq好友被删了怎么恢复(qq好友被删了怎么辅助验证)

  • ios系统制作微视频用什么软件(苹果手机怎样制作微视)

    ios系统制作微视频用什么软件(苹果手机怎样制作微视)

  • cad中怎么查看布局中视口比例(cad怎么查看布局)

    cad中怎么查看布局中视口比例(cad怎么查看布局)

  • 鸿蒙系统怎么安装第三方软件 鸿蒙无法安装外部软件的解决方法(鸿蒙系统怎么安装电脑)

    鸿蒙系统怎么安装第三方软件 鸿蒙无法安装外部软件的解决方法(鸿蒙系统怎么安装电脑)

  • 个体户需要做利润分析吗
  • 企业缴纳个人所得税比例
  • 社保工伤保险可以交两家公司吗
  • 强制解除财务负责人
  • 利润总额和净利润相同说明什么
  • 小规模纳税人增值税优惠政策
  • 工业企业生产费用要素
  • 车间一般性耗用材料会计分录
  • 工会费用是什么意思
  • 企业收到的政府补贴,怎么入账
  • 会计科目的使用说明应包括
  • 企业所得税营业税金及附加
  • 施工费增值税税率是9%
  • 旧税号的发票专用章还能使用吗
  • 社保滞纳金税前怎么算
  • 递延所得税怎么计提
  • 预估材料入账后冲回的步骤
  • 宽带合同要交印花税吗
  • window10主题的颜色浅了
  • 员工离职补偿金计算方法
  • QQExternal.exe是什么进程?QQExternal.exe进程为什么被运行?
  • element ui datepicker 源码
  • 怎样选好布艺沙发
  • 跨年收到退回增值税税款的账务处理
  • 盆栽玉树的养殖方法
  • php二维数组求和
  • 整体租赁合同
  • php memory_get_usage
  • 西安微信公众号开发
  • 凭证字号怎么写
  • 活动策划印花税选哪个税种
  • phpcms怎么样
  • 物业费少交点,有什么理由
  • java如何导出
  • python中如何创建字典
  • 销售折扣现金流量表
  • 房地产企业的固定资产比率越高越好吗
  • 一般纳税人购销合同印花税减免政策
  • 小规模购进原材料可以抵扣税金吗
  • 收到法人投资款需要什么手续
  • 固定资产处置的会计科目
  • 企业所得税季初和季末怎么算
  • 短信收到电子退库收入什么意思
  • 公司前期装修费属于开办费吗
  • 固定资产税前一次性扣除会计处理与税务处理
  • 工程中标费用放哪个科目
  • 增值税可以退吗
  • 个体工商户是否要交税
  • 生产成本增加记哪边
  • mysql在cmd命令操作
  • win10文件夹设置
  • centos环境搭建
  • win10专业版注册表在哪里
  • windows xp.
  • w8网络设置
  • WIN10系统打开IE浏览器断网
  • win7系统鼠标指针形状介绍
  • opengl光照设置
  • sqlite3 not found 解决方案
  • androidannotations的background和UiThread配合使用参考
  • perl 读文件
  • bootstrap需要学多久
  • linux中使用最多的命令
  • jquery给td设置内容
  • node.js的理解
  • python 类的用法
  • python操作数据库语句
  • jquery内容过滤选择器有哪些
  • python re模块findall
  • 211学生占全国比例
  • 个人所得税代扣代缴手续费返还政策
  • 税务申报热线电话
  • 出口退税备案表享受增值税优惠政策
  • 企业以自有物业为单位
  • 税务稽查会打电话吗
  • 地税局跟税务局有什么区别
  • 杜蕾斯验证真伪扫描
  • 北京市工会会员卡免费公园有哪些
  • 东莞国税稽查分局局长
  • 新疆税务电子
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设