我有一个vuejs + firebase项目。

我有三个vuex存储模块,分别是
back, common, front我的商店文件夹结构如下:

src /存储

├───back
│   └───index.js
├───common
│   └───index.js
├───front
│   └───index.js


没有nuxtjs,我可以获取这样的用户通知

    fetchUserNotifications({commit, getters}) {
        let getUser = store.getters["common/getUser"];
        return firebase
            .database()
            .ref("users/" + getUser.id)
            .child("notifications")
            .limitToLast(5)
            .on("value", snapshot => {
                commit("setUserNotifications", snapshot.val());
            });
    },


但是随着nuxt js getUser返回未定义,我认为那是因为我必须在渲染之前获取数据。
我还加了

setTimeout(() => console.log(store.state.front.user), 5000);


但每次结果都为空。
当我在Chrome上检查Vuejs开发人员工具时,一切看起来都很好,我的数据也在那里。

我搜索了文档并找到了nuxtServerInit(),但不知道如何使用它。

老实说,我无法理解nuxtjs,需要像非Nuxtjs项目那样轻松地获取数据的帮助。

最佳答案

据我了解,您的问题主要涉及如何在NuxtJS中设置存储模块。这是一个快速的示例,它说明了如何根据您到目前为止在设置和获取用户以及处理根存储操作中的nuxtServerInit功能方面共享的内容来设置根存储模块:

// store/index.js

export const state = () => ({
  user: null,
  userNotifications: null
})

export const mutations = {
  setUser(state, userData) {
    state.user = userData
  },

  setUserNotifications(state, userNotifications) {
    state.userNotifications = userNotifications
  }
}

export const getters = {
  getUser (state) {
    return state.user
  }
}

export const actions = {
  nuxtServerInit ({ commit }) {
    return httpClient.get('/url/to/get/user/data')
      .then(({ data }) => {
        commit('setUser', data)
      })
  }
}


// where you fetch notifications in a component or page
fetchUserNotifications({commit, getters}) {
  let user = this.$store.getters.getUser();
  return firebase
    .database()
    .ref('users/' + user.id)
    .child('notifications')
    .limitToLast(5)
    .on('value', snapshot => {
      commit('setUserNotifications', snapshot.val());
    });
},
...


如果您有任何疑问,请参阅带有Vuex商店的模块模式下的NuxtJS文档:https://nuxtjs.org/guide/vuex-store

09-13 02:09