这是我第一次使用 Redux,所以请多多包涵,因为我并不真正了解整个事情是如何运作的。我正在尝试访问 CartPlantContainer.js 中的 Redux Store。当console.log(this.props.user)
我得到:
{id: 5, name: "b", email: "b", carts: Array(1)}
但是当我 console.log(this.props.user.carts) 我得到错误:
TypeError:无法读取 null 的属性“购物车”
我不确定我做错了什么。我只想能够传递this.props.user.carts
到我的下一个组件CartPlants
,以便我可以遍历购物车并渲染购物车中的所有植物。
如果您需要任何进一步的信息,请告诉我。我很乐意发送更多我的代码。新手在这里,所以请尝试使用尽可能多的外行术语。先感谢您!
import React, { Component } from 'react'
import {connect} from 'react-redux'
import CartPlants from '../components/CartPlants'
class CartPlantContainer extends Component {
render() {
// This prints fine:
console.log(this.props.user); // Displays "{id: 5, name: "b", email: "b", carts: Array(1)}"
// This fails:
console.log(this.props.user.carts); // Throws TypeError: Cannot read property 'carts' of null
return (
<div>
<CartPlants />
</div>
)
}
}
const mapStateToProps = state => ({
user: state.user.user
})
export default connect(mapStateToProps)(CartPlantContainer)
还有我的用户减速器。
let initialState = {user: {
id: 0,
name: "",
email: "",
carts: [{}]
}
}
export function userReducer(state = initialState, action) {
switch(action.type) {
case LOGIN_USER:
return {
...state,
user: action.user
};
case ADD_CART_PLANT:
return {
...state,
user: {...state.user, carts: [...state.user.carts, action.cart_plant]}
}
default:
return state;
}
}
在后端,我的 API 在用户中嵌套了购物车。商店也描述了这一点。我不确定是否需要为 User 中的每个属性包含一个默认值,或者是否将整个对象设置为 null 就足够了。
当我console.log(this.props.user.carts[0])
现在收到:
{id: 5, checkout: false, user_id: 5, total: 2200, cart_plants: Array(20)}
但是当console.log(this.props.user.carts[0].cart_plants)
我得到:
TypeError:无法读取未定义的属性“cart_plants”
我完全被我做错了什么难住了。
更新:
我向我的对象添加了一个空对象,initialState
并且能够console.log(this.props.user.carts[this.props.user.carts.length-1].cart_plants)
返回 cart_plants 数组。
但是,尝试在单独的generateCartPlants()
函数中映射它们会导致错误
TypeError:无法读取未定义的属性“地图”
generateCartPlants = () => {
const currentCart = this.props.user.carts[this.props.user.carts.length - 1]
const cartPlantData = currentCart.cart_plants.map(cart_plant => {
return <div className="cart-plant-card" key={cart_plant.id}>
<CartPlant id={cart_plant.id} image={cart_plant.plant.image} size={cart_plant.plant.size} price={cart_plant.plant.price} name={cart_plant.plant.name} species={cart_plant.plant.species} exp_level={cart_plant.plant.exp_level} light_required={cart_plant.plant.light_required} pet_friendly={cart_plant.plant.pet_friendly}/>
</div>
})
return cartPlantData
}
**有人有什么想法吗?我真的需要这方面的帮助才能推进我的项目,但我真的被困住了。如果需要,我可以提供更多代码,请告诉我!