我想在调用并执行某些操作后向我的Firebase数据库执行PUT请求。 我的全局状态有一个数组os对象,称为“ items”;我有一些操作可以更新此数组,例如添加对象,删除或编辑其属性。我确实想在添加,编辑或删除请求后立即发送请求
我的代码:
import React, {Component} from 'react'
import { FontAwesomeIcon } from '@fortawesome/react-fontawesome';
import {connect} from 'react-redux'
import axios from '../../axios'
import classes from './List.module.css'
import {Button,ListGroup} from 'reactstrap'
import Input from '../UI/Input/Input'
import Items from './Items/Items'
class List extends Component{
componentWillMount() {
axios.get('/list/items.json')
.then(response=>{
console.log("response.data")
console.log(response.data)
this.props.initialState(response.data)
}).catch(error=>console.log(error))
}
render(){
let inputElement = null
if(this.props.input){
inputElement=(
<Input
changedName={this.props.changedName}
changedDesc={this.props.changedDesc}
addOrEdit={this.props.addItem}
nameInput={this.props.state.nameInput}
descInput={this.props.state.descInput}
buttonText={this.props.state.buttonText}/>
)
}
let editElement = null
if(this.props.state.edit){
editElement=(
<Input
changedName={this.props.changedName}
changedDesc={this.props.changedDesc}
addOrEdit={this.props.editItem}
nameInput={this.props.state.nameInput}
descInput={this.props.state.descInput}
buttonText={this.props.state.buttonText}/>
)
}
let itemElement = null
if(this.props.items && this.props.items.length !== 0 ){
itemElement = this.props.items.map((i,index)=>{
return <Items
className={classes.items}
id={index}
name={i.itemName}
key={index}
deleteClicked={()=>this.props.deleteItem(index)}
itemIndex={()=>this.props.itemIndexChanger(index)}
editInput={()=>this.props.editItemHandler(index)}
editIndex={this.props.state.editIndex}
editElement={editElement}/>
})
}else{
itemElement = <h4 className={classes.items}>Please add an Item</h4>
}
return(
<div className={classes.items}>
<ListGroup>
{itemElement}
</ListGroup>
<hr className={classes.hr}/>
<Button
className={classes.button}
onClick={this.props.toggleInputHandler}
size="sm"
outline color='info'>
Add Items
<FontAwesomeIcon icon='plus'/>
</Button>
{inputElement}
</div>
)
}
}
const mapStateToProps = (state) =>{
return{
items:state.items,
input:state.input,
state:state,
}
}
const mapDispatchToProps = dispatch=>{
return{
toggleInputHandler:()=>dispatch({type:'TOGGLE_INPUT_HANDLER'}),
changedName:(event)=>dispatch({type:'CHANGED_NAME', payload:event.target.value}),
changedDesc:(event)=>dispatch({type:'CHANGED_DESC',payload:event.target.value}),
addItem:()=>{return(dispatch({type:'ADD_ITEM'}))},
deleteItem:(index)=>dispatch({type:'DELETE_ITEM',index:index}),
editItemHandler:(index)=>dispatch({type:'EDIT_ITEM_HANDLER',index:index}),
editItem:()=>dispatch({type:'EDIT_ITEM'}),
itemIndexChanger:(index)=>dispatch({type:'CHANGE_ITEM_INDEX',index:index}),
initialState:(value)=>dispatch({type:'SET_STATE',payload:value})
};
}
export default connect(mapStateToProps, mapDispatchToProps)(List)
需要帮助: 假设我使用addItem分派将对象添加到“项目”数组中,这意味着它将更新状态中的项目。在additem被调用并完全执行后,如何执行axios.put请求,以便可以将更新后的state.items发送到我的Firebase?
谢谢大家的关注!
答案 0 :(得分:1)
使用纯React和Redux,可以使用componentDidUpdate
完成此类工作:
componentDidUpdate(prevProps, prevState) {
if (prevProps.someValue !== this.props.someValue) {
axios.put( /* ...some axios call to sync someValue */ )
}
}
这对于简单的一次性操作是很好的,但是如果您有大量要同步的值,或者想要从不同的组件中进行操作,或者想要踢一脚,这种方法就可以开始变得很粗糙。从动作中消除复杂的异步行为。
这类行为被称为副作用,它们是中间件库(例如redux-thunk和redux-saga)的目的,它们在此领域各有优缺点。
如果您预见到应用程序会大量使用API更新或其他复杂的异步行为等副作用来响应操作,则强烈建议您熟悉其中一个库,而不要走componentDidUpdate
路线。