Axios 请求在 React 中失败
Axios Request Failure In React
我不确定我做错了什么。
我希望 Main
组件将 ajax 请求方法传递给子组件 InputForm
,这将 return 结果存储在 Main
组件状态。
class Main extends React.Component {
constructor( props ){
super( props );
this.state = {
fetching : false,
repos : {}
};
this.getGitHubRepo = this.getGitHubRepo.bind( this );
}
getGitHubRepo( user ){
this.setState({ fetching : true });
console.log( "form submitted!", user );
axios.get( user )
.then(( response ) => {
console.log( "response =>", response );
})
.catch(( error ) => {
console.log( "error => ", error );
});
}
render(){
return(
<div className = "appContainer">
<InputForm getGitHubRepo = { this.getGitHubRepo } />
</div>
);
}
}
class InputForm extends React.Component{
constructor( props ){
super( props );
this.state = {
inputValue : "",
};
this.recordInput = this.recordInput.bind( this );
}
recordInput( e ){
this.setState({ inputValue : e.target.value });
}
render(){
let getPath = `https://api.github.com/${this.state.inputValue}`;
return(
<form onSubmit = {() => this.props.getGitHubRepo( getPath )}>
<label htmlFor = "user_input">
Github Username
</label>
<input id = "user_input"
type = "input"
onChange = { this.recordInput } />
<input type = "submit" value = "get repos" />
</form>
);
}
}
ReactDOM.render( <Main />, document.getElementById( "app" ));
我没有得到任何结果,我的 webpack 服务器刷新了页面。
这里的主要问题是您没有在提交表单时调用 preventDefault。 此外,url 获取 github 回购协议是错误的,但这是次要的。
检查更新的jsbin:https://jsbin.com/sujakexamo/1/edit?js,output
class InputForm extends React.Component{
constructor( props ){
super( props );
this.state = {
inputValue : "",
};
this.recordInput = this.recordInput.bind( this );
this.submit = this.submit.bind(this);
}
recordInput( e ){
this.setState({ inputValue : e.target.value });
}
submit (e) {
e.preventDefault();
this.props.getGitHubRepo( `https://api.github.com/users/${this.state.inputValue}/repos` );
}
render(){
return(
<form onSubmit = {this.submit}>
<label htmlFor = "user_input">
Github Username
</label>
<input id = "user_input"
type = "input"
onChange = { this.recordInput } />
<input type = "submit" value = "get repos" />
</form>
);
}
}