- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我构建了一个小的 React Routing 应用程序,并希望在表单提交成功的 HTTP 响应后测试转发到不同的 React 页面。
单击提交按钮时,将显示红色的提交确认屏幕,但不久之后,浏览器将返回到原始屏幕,并添加了表单参数“/?dummy=dummy”。如果我在 promise 之外进行重定向,例如在 HTTP 调用之前,提交确认屏幕将保留。
是否有有用的替代方法来实现类似的行为?
路由设置:
export default function App() {
return (<Router>
<Switch>
<Route path="/" exact component={TestForm} />
<Route path="/submitted" component={Submitted} />
</Switch>
</Router>
);}
测试组件:
class TestForm extends Component {
submitHandler = () => {
let history = this.props.history;
fetch("https://reqres.in/api/users/6")
.then(response => {
history.push({ pathname: "/submitted" });
});
};
render() {
return (<div>
<form onSubmit={this.submitHandler}>
<input type="text" name="dummy" value="dummy" readOnly /><input type="submit" />
</form>
</div>);}}
export default withRouter(TestForm);
提交确认组件:
const submitted = props => {
let style = { "background-color": "red" };
return <div style={style}>Form has been submitted</div>;
};
完整的代码和行为可以在
sandbox 中测试.
最佳答案
这是因为您没有阻止表单提交事件的默认功能,它正在发布结果。
更新您的事件处理程序以防止默认。
import React, { Component } from "react";
import { withRouter } from "react-router-dom";
class TestForm extends Component {
submitHandler = (e) => {
e.preventDefault()
let history = this.props.history;
fetch("https://reqres.in/api/users/6")
.then(response => {
history.push({ pathname: "/submitted" });
})
.catch(myError => {
console.log(myError);
});
};
render() {
return (
<div>
<form onSubmit={this.submitHandler}>
<input type="text" name="dummy" value="dummy" readOnly />
<input type="submit" />
</form>
</div>
);
}
}
export default withRouter(TestForm);
关于javascript - 当从 promise 转发时,React Router 将重定向回来,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63066120/
我对 Objective C 和 iOS 开发总体来说是新手。我正在尝试创建一个应用程序,它会发出 http 请求并在标签上显示内容。 当我开始测试时,我注意到标签是空白的,尽管我的日志显示我已经恢复
我实现了一个 MVP 应用程序。后退按钮工作正常。我想以编程方式回到以前的地方。我该怎么做? 我正在寻找类似的东西: clientFactory.getPlaceController().goBack
我想从 mySubView 制作后退按钮。我有带有按钮的付款ViewController,这个按钮使view.addSubview(WkWebView)。所以我可以打开 WkWebView 但我不可能
我有一个 master 分支,里面有很多不会发布的特性。我被要求从 master 中删除这些功能并创建一个包含它们的新分支,以便我们稍后可以 merge 回 master。 我采取的步骤是: 在 ma
如何禁用页面上的所有 onclick 事件,绑定(bind)我的自定义函数,并在执行后启用所有之前的事件? 我正在构建一个小书签,它应该适用于任何已加载的页面,并且我正在使用 jQuery 来处理我的
我正在尝试从 Spotify api 接收 token 。不幸的是,我一直收到 415。你能帮帮我,让我知道我做错了什么吗? const axios = require('axios'); const
我有一个提供上下文的函数: def buildContext(s:String)(request:RequestHeader):Future[Granite.Context] = { ....
我有一个列表,其中包含几个不同形状的 numpy 数组。我想将这个数组列表 reshape 为一个 numpy 向量,然后更改向量中的每个元素,然后将其 reshape 回原始数组列表。 例如: 输入
我目前有这个工作 fiddle - http://jsfiddle.net/B8Abd/ 我想在函数中使用 jquerys 淡出然后淡入。目前的代码是这样的: function chan
我有 2 个分支,一个是 main 分支,另一个是我正在开发一个 parallel 版本。 A --> B --> C (master) \ -> E --> F (parallel) pa
我试图从我的“ super 项目”中的文件目录中创建一个“子项目”以与其他人一起工作,但我一直在努力使其在 git subtree 中工作。 理想情况下,其他人可以在子项目上工作,然后我从上游更改中提
有没有其他人看到这个? 我正在使用带有回形针的 rails 3,当我上传 .doc 时,它的应用程序/msword 效果很好,但是当我上传 .docx 时,content_type 被保存为应用程序/
我是一名优秀的程序员,十分优秀!