我想访问gun
服务器和客户端的变量。
这是我的模块:
import Gun from 'gun/gun'
import Sea from 'gun/sea' // eslint-disable-line no-unused-vars
export const gun = Gun({
localStorage: true,
radisk: true,
peers: ['http://localhost:8765/gun']
})
如果它是 a Nuxt
,我想放弃它以支持 a Sapper
,我会像这样实现它:
import Gun from 'gun/gun'
import 'gun/sea'
import 'gun/lib/open'
const gun = Gun({
localStorage: true,
radisk: true,
peers: ['http://localhost:8765/gun']
})
export default ({ app }, inject) => {
inject('gun', () => gun)
}
// nuxt.config.js
...
plugins: [{ src: '@/plugins/gun.js' }]
...
因此,我可以访问$gun
任何地方:
在服务器端:
export default {
asyncData(context){
context.app.$gun()
}
}
在客户端:
methods: {
submit() {
const gun = this.$gun()
const user = this.$gun().user()
...
}
}
而且在模板中:
<template>
<div>{{ $gun }}</div>
</tempalte>
该问题与问题 ( gun
) 中讨论的特定库的使用无关。它可以是一个Websocet
连接(然后我们将以ws
相同的方式传递变量 sun。),或一个 rpc(用于连接Bitcoin
)——我可以举出许多例子,说明这很重要。
在某处我读到你需要通过rollbar
,某处我读到一个常规模块(es6
或.svelte
)来实现这个 - 但后来我遇到了许多其他问题......