如何在应用程序呈现时从firestore获取集合并设置为vuex状态?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了如何在应用程序呈现时从firestore获取集合并设置为vuex状态?相关的知识,希望对你有一定的参考价值。

我有一个名为categories的firestore集合。这个集合中的文档被我的vue应用程序中的每个页面(路由)使用,所以我认为访问这些数据的最有效方法是在store.js中有一个类别状态,这样每个组件都可以访问类别状态当它需要而不是每次从firestore获取它。在呈现应用程序时,如何将类别集合的内容设置为我的vuex状态?

这是我的store.js:

import Vue from 'vue'
import Vuex from 'vuex'
const fb = require('./components/firebase/FirebaseConfig.js')

Vue.use(Vuex)

export const store = new Vuex.Store({
    state: {
        categories: []
    },
    actions: {
        fetchCategories({commit, state}) {
            fb.categoriesCollection.get().then((querySnapshot) => {
                if (querySnapshot.empty) {
                    //this.$router.push('/HelloWorld')

                } else {
                    this.loading = false
                    var categories = []
                    querySnapshot.forEach((doc) => {
                        categories.push(doc.data());
                    })

                    this.categories = categories
                }
         })
    },  
    mutations: {
        setCategories(state, val) {
            state.categories = val
        }
    }
})

我知道我可以使用以下方法调用fetchCategories:

this.$store.dispatch('fetchCategories')

但我不确定在哪里放这个。

答案

以下应该做的伎俩:

import Vue from 'vue'
import Vuex from 'vuex'
const fb = require('./components/firebase/FirebaseConfig.js')

Vue.use(Vuex)

fb.categoriesCollection.get().then((querySnapshot) => {
    if (querySnapshot.empty) {
          //this.$router.push('/HelloWorld')

    } else {
        this.loading = false
        var categories = []
        querySnapshot.forEach((doc) => {
             categories.push(doc.data());
        })
        store.commit('setCategories', categories)
    }
});

export const store = new Vuex.Store({
    state: {
        categories: []
    },
    actions: {
        //.....
    },  
    mutations: {
        setCategories(state, val) {
            if (val) {
                state.categories = val
            } else {
                state.categories = []
            }
        }
    }
})

以上是关于如何在应用程序呈现时从firestore获取集合并设置为vuex状态?的主要内容,如果未能解决你的问题,请参考以下文章

如何获取firestore集合下的文档数量? [复制]

Firestore 从集合中获取数组

Firestore:如何在集合中获取随机文档

Firestore - 如何在将文档添加到集合后获取文档 ID

如何根据 Firestore 数据库中的字段从集合中搜索文档?

FIRESTORE - 如何在文档中获取集合的值?