小さなvuejs
アプリケーションを使い始める。ルートコンポーネントでwebsocket接続を開き、他のコンポーネントで同じ接続を再利用する方法を教えてください。vuejs - コンポーネント間のWebSocket接続を共有する
コンポーネントが同じ接続で送受信できるようにします。 これらのコンポーネントはルートに結び付けられ、ルートコンポーネントとルート用にレンダリングされたコンポーネントの間に直接的な親子関係は存在しません。
App.vue:
<template>
<div id="app">
<h1>My app</h1>
<router-link to="/">P&L</router-link>
<router-link to="/other-page">other page</router-link>
<router-view></router-view>
</div>
</template>
<script>
export default {
name: 'app',
data() {
return {
ws: null
}
},
created() {
this.ws = new WebSocket('ws://localhost:8123/ws')
},
methods: {
}
}
}
</script>
今、私はルートを変更するたびに再接続しないようother-page
にws
を再利用したいと思います。
涼しいおかげで:私はできるだけ多くの構文を好きではないけれどもまたはあなたが、このいずれかを使用することができます。関連する文書:行動の下にあるhttps://router.vuejs.org/ja/api/router-view.htmlまた、サーバーとクライアントをsocket.ioに切り替え、https://github.com/MetinSeylan/Vue-Socket.io vue-socket.ioプラグインを使用しました。これにより、どのコンポーネントでもソケットを使用できるようになります。 – neric
これは私のためには機能しません。 – chovy
@チョビあなたは何か間違ったことをしました。 – Bert