首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >yup的条件验证

yup的条件验证
EN

Stack Overflow用户
提问于 2021-06-10 22:38:14
回答 1查看 256关注 0票数 0

我有3个字段在表单中,“类型”字段是选择和从列表中,一些项目启用或禁用“输出”字段,如果是启用,我需要“输出”字段小于“输入”字段,反之亦然,但如果“输出”字段是禁用我不需要的验证,我正在尝试与.when的东西,但没有工作,有什么想法如何做呢?

代码语言:javascript
复制
  const [disableOutCounterField, setDisableOutCounterField] = useState(false);

  const schema = yup.object().shape({
    type: yup.string().required(requiredMessage),
    in: yup
      .number(numberMessage)
      .required(requiredMessage)
      .integer(integerMessage)
      .min(1, positiveMessage)
      .typeError(numberMessage)
      .when("out", {
        is: !disableOutCounterField,
        then: yup.number().moreThan(yup.ref("out"), moreThanMessage),
        message: moreThanMessage,
      }),
    out: yup
      .number(numberMessage)
      .integer(integerMessage)
      .typeError(numberMessage)
      .lessThan(yup.ref("in"), lessThanMessage),
  });
EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2021-06-10 23:17:48

构造:

代码语言:javascript
复制
.when("out", {
  is: !disableOutCounterField,

out值与!disableOutCounterField值进行比较,如果它们相等,则应用then规则。但它们很可能永远不是一样的。

对于out的任何值,这里需要的检查就是!disableOutCounterField本身的值。这可以使用表达式来完成:

代码语言:javascript
复制
.when("out", {
  is: value => !disableOutCounterField,

换句话说:对于每个out值,返回!disableOutCounterField,如果返回true,则应用then部分。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/67923407

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档