我使用路由器进行路由。有一个产品列表,单击产品时,应显示该产品的详细信息页面(product.name,product.price)。我尝试在查询中传递产品对象,但它没有那样工作。
这是我的代码
productGrid.js
const product = _.map(products, (product) =>
<Col xs={12} md={4} key={product.id} className="products">
<div className="product">
<Link to={{pathname: `product/${product.name}`, query: { query: product }}}>
<img src={product.image} className="img-responsive" />
</Link>
<span className="pull-left product-name">{product.name}</span>
<span className="pull-right price">${product.price}</span>
</div>
</Col>
);
产品view.js
class ProductView extends React.Component {
render() {
console.log('product', this.props.location.query);
return (
<div>Product View</div>
);
}
}
this.props.location.query控制台
答案 0 :(得分:1)
位置描述符的query
对象将变为查询字符串。您可以使用位置描述符的state
property在视图之间传递状态。
<Link to={{ pathname: `product/${product.name}`, state: { product } }}>
然后,在您的产品组件中,您可以检查this.props.location.state
以获取相关数据。这样做的缺点是,直接导航到同一URL的用户将无法使用state
。
答案 1 :(得分:1)
我建议您将产品列表props
传递给ProductView
,然后检索带有id
的产品。这样,当用户直接导航到产品时,没有任何缺点。
<强> productGrid.js 强>
<Link to={{pathname: `product/${product.name}`, query: { id: product.id }}}>
<强>产品view.js 强>
class ProductView extends React.Component {
render() {
const { products, location } = this.props;
if (!products.length || !location) {
return (<div>Loading...</div>);
}
const product = products.find(p => p.id == location.query.id);
return product ? (
<div>
<h1>{product.name}</h1>
<img src={product.image} />
<p>{product.price}</p>
</div>
) : (
<div>Error: Product doesn't exist</div>
);
}
}