her*_*ose 2 reactjs reselect react-router-dom react-hooks mapstatetoprops
我收到一个来自 的 url 参数useParams。我想使用将它传递给选择器mapStateToProps。
集合.组件.jsx
import { useParams } from "react-router-dom";
import { connect } from "react-redux";
import { selectShopCollection } from "../../redux/shop/shop.selectors";
import './collection.styles.scss'
const Collection = ({ collection }) => {
const { collectionId } = useParams();
console.log(collection)
return (
<div>
<h1>{collection}</h1>
</div>
)
}
const mapStateToProps = (state, ownProps) => ({
collection: selectShopCollection(ownProps.match.params.collectionId)(state)
})
export default connect(mapStateToProps)(Collection);
Run Code Online (Sandbox Code Playgroud)
shop.selectors.js
import { createSelector } from "reselect"
const selectShop = state => state.shop
export const selectShopCollections = createSelector([selectShop], shop =>
shop.collections
)
export const selectShopCollection = collectionUrlParam =>
createSelector([selectShopCollections], collections =>
collections.find(collection => collection.id === collectionUrlParam)
)
Run Code Online (Sandbox Code Playgroud)
我想问题是,我无法使用 match 传递参数,因为 React-router-dom v6 没有在 props 中传递它。还有其他方法可以传递collectionId给选择器吗selectShopCollection?
由于Collection是一个函数组件,我建议useSelector从中导入钩子react-redux,以便您可以直接传递collectionId匹配参数。它简化了组件 API。reselect选择器与钩子配合得很好useSelector。
import { useParams } from "react-router-dom";
import { useSelector } from "react-redux";
import { selectShopCollection } from "../../redux/shop/shop.selectors";
import './collection.styles.scss'
const Collection = () => {
const { collectionId } = useParams();
const collection = useSelector(selectShopCollection(collectionId));
console.log(collection);
return (
<div>
<h1>{collection}</h1>
</div>
)
};
export default Collection;
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
1017 次 |
| 最近记录: |