在类星体框架中存储全局对象的位置

where to store global object in quasar framework

我正在使用 Quasar Framework which is based on Vue 重写我的旧应用程序,并且我有一段代码 (class) 封装了 websocket 功能。

这是一个相当简单的概念:用户在应用程序中从一个页面移动到另一个页面,但如果他收到一条消息,他可以看到祝酒词 message/reply 或 unread messages 递增的计数器。

我有点迷失在 Quasar (Vue) 架构中,这是我的问题:

我应该在哪里存储与外界通信的全局对象,只要应用程序存在并且可以从任何地方访问就存在?

我阅读了 Quasar (Vue) 的文档,但我仍然不知道该把它放在哪里。 Vuex 看起来不对,因为它不是应用程序的状态。更像是一个无脸组件

这是否意味着我应该使用插件或 Vue.prototype 或全局混合或其他东西?

如果有人可以分享他们的经验和描述如何初始化和访问此对象方法的一段代码,我将不胜感激。

我认为:

方法一、使用基于Vue原型的quasar插件(你肯定知道):

plugins/foo.js

const fooModule = {
  a: 1,
  doTest() { console.log('doTest') }
};
export default ({Vue}) => {
  Vue.prototype.$foo = fooModule;
}

quasar.conf.js

plugins: [
  'i18n',
  'axios',
  'foo',
],

组件bar.vue:

methods: {
   test () { this.$foo.doTest() }
}

方法二,使用js模块即可

因为js模块是单例的。无论你在哪里导入一个js模块,它都指向同一个指针。

所以只要 GlobalTest.js:

export default {
  a: 1,
  inc() { this.a = this.a + 1 }
}

和test1.js:

import GlobalTest from '/path/to/GlobalTest'
console.log(GlobalTest.a); // output 1
console.log(GlobalTest.inc()); // inc

和test2.js:

import GlobalTest from '/path/to/GlobalTest'
console.log(GlobalTest.a); // Assuming this was called after test1.js: output 2

我使用了 quasar cli,但我只是将 quasar 视为 UI 库。

--- 更新了 ---

It is a fairly simple concept: user travels from page to page in the app, but if he receives a message he can see a toast message/reply or a counter of unread messages increments.

取决于需求,如果你需要 "reactive" 你应该使用 Vuex(最好的内置反应库)+ 将应用程序状态拆分为模块, 但我只在需要 "reactive" 时才使用 Vuex,而在只需要读取和写入值时避免使用它。

// ~/store/index.js
import Vue from 'vue'
import Vuex from 'vuex'

Vue.use(Vuex)

let store
export default function (/* { ssrContext } */) {
  /* eslint-disable no-return-assign */
  return store = new Vuex.Store({
    modules: {...},
    strict: process.env.DEV
  })
}

export function ensureClientStoreExists () {
  if (process.env.SERVER) {
    return new Promise(() => { /* won't resolve */ })
  }
  if (process.env.CLIENT) {
    if (store) {
      return Promise.resolve(store)
    }
    return new Promise(resolve => {
      setTimeout(resolve) // Avoid 'Maximum call stack size exceeded'
    }).then(ensureClientStoreExists)
  }
}
// Anywhere
import { ensureClientStoreExists } from '~/store/'

ensureClientStoreExists().then(store => {
  console.log(store.state)
  store.dispatch('XXX/YYY')
})