繁体   English   中英

Vuejs-nuxt(SSR 模式)无法通过插件内的 getter 获取 UserUUID。 它显示未定义的 GetUserUUID

[英]Vuejs-nuxt (SSR Mode) not able to get UserUUID through getter inside plugins. It shows undefined for GetUserUUID

我在我的 vuejs-nuxt 项目中使用 SSR 模式。 因此,每当我尝试调用套接字事件时,我都需要将用户 ID 从商店传递给该套接字。 GetUserUUID getter 在所有其他 API 中都可以正常工作。 但只有在从“plugin/socketio.js”文件调用的情况下才会失败。 我需要一些帮助才能从 getter 获取数据。

插件/socketio.js

export default async ({ store, $axios }) => {
   console.log(store.getters.GetUserUUID,"Current User UUID which is showing undefined");

function listenStock({ channelName, eventName }, callback) {
console.log("callback",callback);
window.Echo.channel(channelName).listen(eventName, callback);
}

//Fetch user data
listenStock(
 {
  channelName: `BalanceUpdateEvent.${store.getters.GetUserUUID}`,
  eventName: "BalanceUpdateEvent"
 },
 ({ data }) => {
   console.log(data, "socket data");
   try {
     store.dispatch("setUserBalance", data.data.userBalance);
   } catch (ex) {
     console.log(ex);
   }
 }
);

nuxt.config.js

plugins: [
  { src: '~/plugins/socketio', mode: 'client' }
]
echo: {
   plugins: ['~/plugins/socketio.js']
},

此图像是 console.log(store.getters) 的结果,但我需要访问 GetUserUUID。

请在 nuxt.config.js 中尝试

export default {
  plugins: [
    ....
    { src: '~/plugins/socketio.js', mode: 'client' }, // only on client side
    ...
  ]
}

在客户端运行你的插件

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM