首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >React-Redux-Firebase新挂钩

React-Redux-Firebase新挂钩
EN

Stack Overflow用户
提问于 2020-01-07 21:57:45
回答 1查看 468关注 0票数 1

我已经设置了redux和react,它们工作得很好。我现在想使用钩子useFirestoreConnect和useFirestore()将数据从firestore直接同步到redux状态。

下面的代码可以工作:

代码语言:javascript
复制
function BannerG() {

    const dispatch = useDispatch()
    // const banneAG = useSelector(state => state.banneAG)

    const firestore = useFirestore();
    useFirestoreConnect( props => [{collection : "layoutElements", doc: 'BannerG'}])
    const aa = useSelector(state  => state.firestore.data.layoutElements)
    console.log(aa)

在控制台中,对象打印为{BannerG:{H1: blah,H2:Blah blah,…………}}

但是如果我改用

代码语言:javascript
复制
function BannerG() {

    const dispatch = useDispatch()
    // const banneAG = useSelector(state => state.banneAG)

    const firestore = useFirestore();
    useFirestoreConnect( props => [{collection : "layoutElements", doc: 'BannerG'}])
    const aa = useSelector(state  => state.firestore.data.layoutElements.BannerG)
    console.log(aa)

当我运行时,返回一个错误,指出BannerG是未定义的。如果我尝试使用后一个,aa.BannerG.H1也会给出错误

有谁有办法解决这个问题吗?

EN

回答 1

Stack Overflow用户

发布于 2020-01-13 19:30:35

我不能直接在任何参考文献中找到它,但只能在示例中找到。

看起来useSelector需要像这样的方括号:

代码语言:javascript
复制
const aa = useSelector(state  => state.firestore.data.layoutElements['BannerG'])

我在示例github react-redux-firebasereact-reduxreact-redux-firebase.com reference中发现了如下内容。

不幸的是,我现在不能测试它,所以请让我知道它是否工作。

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/59629870

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档