Using Vuex with Nuxt and Vue-Native-Websocket

The name of the pictureThe name of the pictureThe name of the pictureClash Royale CLAN TAG#URR8PPP


Using Vuex with Nuxt and Vue-Native-Websocket



I'm trying to fill my vuex store with data from websocket. I'm using Nuxt. For handling websocket I'm using vue-native-websocket package. Connection to websocket is successful, but commiting to the store doesn't work, it fires an error on every socket event Uncaught TypeError: this.store[n] is not a function


Uncaught TypeError: this.store[n] is not a function



According to Nuxt and vue-native-websocket docs, I've using them as following:



Plugin native-websocket.js:


import Vue from 'vue'
import VueNativeSock from 'vue-native-websocket'
import store from '~/store'

Vue.use(VueNativeSock, 'wss://dev.example.com/websocket/ws/connect', { store: store })



nuxt.config.js


plugins: [
{src: '~plugins/native-websocket.js', ssr: false}
],



As the connection is established, I draw a conclusion that the package is connected right, so it's something about store and I can't get what's wrong



UPD: After some workaround I've found out that logging store inside native-websocket.js returns


store() {
return new __WEBPACK_IMPORTED_MODULE_1_vuex__["default"].Store({
state: {...my store



and commiting to it returns __WEBPACK_IMPORTED_MODULE_2__store__.default.commit is not a function
So it's something about webpack as I can see


__WEBPACK_IMPORTED_MODULE_2__store__.default.commit is not a function





Use a callback as the 3rd argument instead, passToStoreHandler: function (eventName, event) {, inside of here log out this.store what is the value
– Ohgodwhy
7 hours ago




passToStoreHandler: function (eventName, event) {


this.store





@Ohgodwhy I've tried just now, console is clear, callback doesn't fire { passToStoreHandler: function(eventName, event) { console.log(this.store); console.log('test') }}
– Elijah Ellanski
6 hours ago




{ passToStoreHandler: function(eventName, event) { console.log(this.store); console.log('test') }}





@Ohgodwhy Sorry, I've forgot pass the store to that object. Now console.log returns my store(), but there is no error only if callback is passed to third argument object. No commits are made to store anyway
– Elijah Ellanski
6 hours ago


store()





Maybe try building the commit yourself and committing to the store. Does that work?
– Ohgodwhy
6 hours ago





@Ohgodwhy Tried this.store.commit('incrementCounter') inside of passToStoreHandler. Got this.store.commit is not a function
– Elijah Ellanski
5 hours ago


this.store.commit('incrementCounter')


passToStoreHandler


this.store.commit is not a function




1 Answer
1



You need to import store differently e.g. get it from context of plugin. Here some docs, but they somewhat lacking


import Vue from 'vue'
import VueNativeSock from 'vue-native-websocket'

export default ({ store }, inject) => {
Vue.use(VueNativeSock, 'wss://dev.example.com/websocket/ws/connect', { store: store })
}






By clicking "Post Your Answer", you acknowledge that you have read our updated terms of service, privacy policy and cookie policy, and that your continued use of the website is subject to these policies.

Popular posts from this blog

Keycloak server returning user_not_found error when user is already imported with LDAP

Using generate_series in ecto and passing a value

PHP parse/syntax errors; and how to solve them?