社区首页 >问答首页 >响应Formik不调用onSubmit函数

响应Formik不调用onSubmit函数
EN

Stack Overflow用户
提问于 2022-09-28 14:38:00
回答 2查看 70关注 0票数 0

我有一个Formik表单,在布局中使用react引导,为验证使用yup,如下所示:

代码语言:javascript
代码运行次数:0
复制
import React, { useEffect, useState } from "react";
import { useHistory } from "react-router-dom";
import { useParams } from "react-router-dom";
import { Formik, Field } from "formik";
import * as Yup from 'yup';

import 'bootstrap/dist/css/bootstrap.min.css';
import Button from 'react-bootstrap/Button';
import Form from 'react-bootstrap/Form';
import Row from 'react-bootstrap/Row';
import Col from 'react-bootstrap/Col';


const VehicleForm2 = ({ action = "create" }) => {
  const history = useHistory();

  const VehicleValidationSchema = Yup.object().shape({
    vehicleMake: Yup.string()
      .required('Vehicle Make is required'),
    vehicleModel: Yup.string()
      .required('Vehicle Model is required')
 });

const [initialValues, setValues] = useState({
    vehicleMake: "",
    vehicleModel: ""
  });

const { id = "" } = useParams();
  const handleSubmit = async (values) => {
    var receivedData = "";
    console.log("ENTERED SUBMIT METHOD");
    try {
      if (action === "create") {
        await axios.post(`${process.env.REACT_APP_BASE_URL}/vehicle/add`, {
          ...values,
        }).then(function (response) {
          receivedData = response.data.Message;
        });}
      else {
        await axios.patch(
          `${process.env.REACT_APP_BASE_URL}/vehicle/edit/${id}`,
          {
            ...values
          }
        );
      }
      history.push({pathname: '/vehicles',
        state: { message: receivedData }
      });
    } catch (error) { console.log(error)}
  };

 return (
    <Formik       
    initialValues={initialValues}
    onSubmit={handleSubmit}
    validationSchema={VehicleValidationSchema}
    render={({handleChange, handleSubmit, handleBlur, values, errors}) => (
      <Form onSubmit={handleSubmit}>
        <Row>
          <Col>
            <Form.Label>Make</Form.Label>
            <Form.Control type="text" name="make" defaultValue={initialValues.make} placeholder="Enter make" />
          </Col>
          <Col>
            <Form.Label>Model</Form.Label>
            <Form.Control type="text" name="vehicleModel" defaultValue={initialValues.vehicleModel} placeholder="Enter vehicle model" />
          </Col>
          <Row>
            <Button variant="primary" type="submit" style={{ width: "50%", margin: "auto" }}>
              {action === "create" ? "Create Vehicle" : "Edit Vehicle"}
            </Button>
          </Row>
      </Form>
    )}
/>

在加载“编辑车辆”表单时,所有字段都将按预期填充。但是,当我更改字段的值并按Submit按钮时,似乎没有输入handleSubmit函数(因为handleSubmit()函数顶部的控制台日志没有打印)。相反,该页只是重新加载和显示原始值,而不是更改。

另外,在清除输入并将选项卡显示到下一个输入时,验证不会启动。

你能帮我找出我做错了什么吗?

谢谢。

EN

回答 2

Stack Overflow用户

发布于 2022-09-28 15:18:14

我认为验证失败了,因为您正在寻找vehicleMake,而不是通过了make

代码语言:javascript
代码运行次数:0
复制
const [initialValues, setValues] = useState({
    vehicleMake: "",
    vehicleModel: ""
  });

<Form.Control type="text" name="make" defaultValue={initialValues.make} placeholder="Enter make" />

所以我认为你需要更新name="vehicleMake"initialValues.vehicleMake

票数 0
EN

Stack Overflow用户

发布于 2022-10-02 19:38:48

您试过在表单上删除onSubmit吗?您只需要将onSubmit添加到Formik提供程序

代码语言:javascript
代码运行次数:0
复制
<Formik onSubmit={handleSubmit}>
  <Form>
  </Form>
</Formik>

如果上面的内容不起作用,请尝试使用来自formik的表单。例如:

代码语言:javascript
代码运行次数:0
复制
import Formik, {Form} from "formik"
import BootstrapForm from "react-bootstrap/Form"
...
<Formik onSubmit={handleSubmit}>
  <Form>
     <Row>
          <Col>
            <BootstrapForm.Label>Make</BootstrapForm.Label>
             ...
          </Col>
     </Row>
  </Form>
</Formik>
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/73888507

复制
相关文章
如何使用RVM在FreeBSD 10.1上安装Ruby on Rails
Ruby on Rails,简称RoR,是一个用Ruby编写的非常流行的全栈Web应用程序开发框架。它允许您快速开发符合MVC(模型 - 视图 - 控制器)模式的Web应用程序。
一步
2018/10/10
4.6K0
SQL Server2000安全设置内容
查看存储过程对应文件名命令:sp_helpextendedproc “存储过程名”
全栈程序员站长
2021/04/28
7400
Navicat连接SQL Server2000提示错误08001
大家好,又见面了,我是你们的朋友全栈君。 数据库是SQL Server 2000 ---- 问题描述 无论是本机的数据库还是局域网内的,都出现如图的提示 使用系统自带的“SQL查询分析
全栈程序员站长
2022/09/27
1.9K0
如何使用Passenger和Nginx部署Rails
如果您是Ruby on Rails开发人员,可能需要Web服务器来托管您的Web应用程序。本教程将向您展示如何使用Phusion Passenger。作为Rails的Web服务器,Passenger易于安装,配置和维护,可与Nginx或Apache一起使用。在本教程中,我们将在Ubuntu上安装带有Nginx的Passenger。
乌鸦
2018/08/06
5K0
如何使用Passenger和Nginx部署Rails
使用rvm在Mac中安装ruby和rails
MacOS默认安装的是ruby 1.8.7,如果你想使用ruby 1.9.2的话,除了在官网下载源码编译安装外,可以使用rvm来协助安装。
EltonZheng
2021/01/22
3.2K0
在 FreeBSD 10.2 上安装使用 Nginx 的 Ghost
Node.js 是用于开发服务器端应用程序的开源的运行时环境。Node.js 应用使用 JavaScript 编写,能在任何有 Node.js 运行时的服务器上运行。它跨平台支持 Linux、Windows、OSX、IBM AIX,也包括 FreeBSD。Node.js 是 Ryan Dahl 以及在 Joyent 工作的其他开发者于 2009 年创建的。它的设计目标就是构建可扩展的网络应用程序。
用户8989785
2021/09/10
1.4K0
ruby on rails使用笔记
如果升级过程中说xcode版本太低 还得先升级xcode 重启电脑后继续升级ruby 升级完系统依然报错说xcode版本太低可以使用以下命令切换xcode版本
lilugirl
2019/05/28
1.1K0
使用rails实现最简单的CRUD
这里定义了路由hello/index,并且使用root方法将首页修改为了hello控制器下的index方法,也就是两路由的控制器一致。
用户1515472
2019/07/24
3.2K0
Rails MVC 和 CRUD(12)
保存成功就直接显示,如果保存失败,就重绘 new 页面,new 页面中加入了对错误信息的显示
franket
2021/11/25
2550
Rails MVC 和 CRUD(2)
MVC 分块设计有助于管理复杂的应用程序,因为可以在一段时间内只用关注一个方面;例如,可以在不依赖业务逻辑的情况下专注于视图设计;同时也让应用程序的测试更加容易;MVC 分层同时也简化了分组开发;不同的开发人员可同时开发视图、控制器逻辑和业务逻辑
franket
2021/11/24
3750
Rails MVC 和 CRUD(5)
创建了一个叫 ArticlesController 的类,继承自 ApplicationController
franket
2021/11/24
3390
Rails MVC 和 CRUD(7)
(这里的 /articles 明明对应两个方法,GET、POST ,有点不太明白,为什么这样指定就一定成了POST请求)
franket
2021/11/24
1960
Rails MVC 和 CRUD(9)
保存数据 修改 create 方法,对提交的数据进行保存 [root@h202 blog]# vim app/controllers/articles_controller.rb [root@h202 blog]# cat app/controllers/articles_controller.rb class ArticlesController < ApplicationController def new end def create # render plain: params
franket
2021/11/25
1900
Rails MVC 和 CRUD(15)
点击 【Destroy】 后会根据我们的定义弹出提示 连续删除几次后所剩无几 目前已经通过 Rails 实现了文章的 新建、显示、列出、更新、删除 操作 ---- 命令汇总 rails server -b 0.0.0.0 rails generate controller welcome index cat app/views/welcome/index.html.erb vim config/routes.rb grep -v " #" config/routes.rb | grep -v
franket
2021/11/25
3490
Rails MVC 和 CRUD(13)
定义 update 方法,并且添加 edit 链接和 show 链接 [root@h202 blog]# vim app/controllers/articles_controller.rb [root@h202 blog]# cat app/controllers/articles_controller.rb class ArticlesController < ApplicationController def new @article = Article.new end def
franket
2021/11/25
1620
Rails MVC 和 CRUD(3)
要在 Rails 中显示“My first test” 的静态页面,需要新建一个控制器和视图
franket
2021/11/24
7150
Rails MVC 和 CRUD(8)
再次提交一回 ---- 创建模型 Rails 提供了一个生成器用来创建模型 [root@h202 blog]# bin/rails generate model Article title:string text:text Running via Spring preloader in process 13216 invoke active_record create db/migrate/20160422140912_create_articles.rb c
franket
2021/11/25
2570
Rails MVC 和 CRUD(1)
Rails 的相关基础,详细可以参考 官方文档 和 Ruby China 的 Rails 入门
franket
2021/11/24
3480
Rails MVC 和 CRUD(6)
不过,通过查看源码,我们可以看到 action 部分指向的是当前页面 action="/articles/new" , 而这个页面 (Restfull API) 应该是用来进行显示的,而不是进行处理的
franket
2021/11/24
2700
Rails MVC 和 CRUD(10)
再次加载 可以成功显示了 ---- 列出所有文章 [root@h202 blog]# vim app/controllers/articles_controller.rb [root@h202 blog]# cat app/controllers/articles_controller.rb class ArticlesController < ApplicationController def new end def create # render plain: params[:ar
franket
2021/11/25
1820

相似问题

条件样式表设置:使用模块

20

自定义打印模块的打印样式表

10

自定义样式表

10

如何以drupal方式在drupal 7中添加IE特定样式表

10

当使用Omega响应主题时,IE7和IE8加载所有样式表

10
添加站长 进交流群

领取专属 10元无门槛券

AI混元助手 在线答疑

扫码加入开发者社群
关注 腾讯云开发者公众号

洞察 腾讯核心技术

剖析业界实践案例

扫码关注腾讯云开发者公众号
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
查看详情【社区公告】 技术创作特训营有奖征文