返回顶部
首页 > 资讯 > 前端开发 > JavaScript >Vue+Electron下Vuex的Dispatch没有效果怎么办
  • 689
分享到

Vue+Electron下Vuex的Dispatch没有效果怎么办

2024-04-02 19:04:59 689人浏览 泡泡鱼
摘要

这篇文章将为大家详细讲解有关Vue+Electron下Vuex的Dispatch没有效果怎么办,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。这个问题是解决基于 vue 和

这篇文章将为大家详细讲解有关Vue+Electron下Vuex的Dispatch没有效果怎么办,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。

这个问题是解决基于 vue 和 electron 的开发中使用 vuex 的 dispatch 无效的问题,即解决了 Please, don't use direct commit's, use dispatch instead of this. 问题。

先允许我梳理一下目录结构,以便阅读的时候不会一头雾水,你到底说的这个文件是哪个……

Vue+Electron下Vuex的Dispatch没有效果怎么办

其中 /src/main 是存放主配置文件的,/src/render 下面有 store、router、components 等。

components 下面就是很多 .vue 文件,router 下面就是一些路由配置的 js 文件和一些拦截器的 js。

关键是 store,store 下面有一个 index.js 的主配置文件 index.js,和一个 modules 文件夹。

index.js 里面写的是(记住这句话,后面会用到):

import Vue from 'vue'
import Vuex from 'vuex'
import { createPersistedState, createSharedMutations } from 'vuex-electron'
import modules from './modules'
Vue.use(Vuex)
export default new Vuex.Store({
 modules,
 plugins: [
 createPersistedState(),
 createSharedMutations()
 ],
 strict: process.env.node_ENV !== 'production'
})

而 modules/ 下面存放各个实体,例如上图中的 Auth.js 和 Counter.js,并通过 index.js 全部引入。


const files = require.context('.', false, /\.js$/)
const modules = {}
files.keys().forEach(key => {
 if (key === './index.js') return
 modules[key.replace(/(\.\/|\.js)/g, '')] = files(key).default
})
export default modules

然后来看一个 vuex 的官方样例:

const state = {
 main: 0
}
const mutations = {
 DECREMENT_MAIN_COUNTER (state) {
 state.main--
 },
 INCREMENT_MAIN_COUNTER (state) {
 state.main++
 }
}
const actions = {
 someAsyncTask ({ commit }) {
 // do something async
 commit('INCREMENT_MAIN_COUNTER')
 }
}
export default {
 state,
 mutations,
 actions
}

之后很显然的,我想要在 Vue 的组件调用 INCREMENT_MAIN_COUNTER 对计数器加 1。

this.$store.commit('INCREMENT_MAIN_COUNTER');
// this.$store.commit('INCREMENT_MAIN_COUNTER', payload);

如果是一般的 vue,就 OK 了,但是,我遇到了报错,说,Please, don't use direct commit's, use dispatch instead of this.

Vue+Electron下Vuex的Dispatch没有效果怎么办

那好吧,没事,不就是不然用 Commit,非要用 Dispatch 嘛,那我就写一个 Action,里面直接调用 Mutation,就像这个样子:

const actions = {
 JUST_INCREASE ({ commit }) {
 commit('INCREMENT_MAIN_COUNTER')
 }
}

然而奇怪的事情是,this.$store.dispatch('JUST_INCREASE') 并不能运行,没反应,计数器还是 0,不能赋值,就像是这个函数没有被执行一样。没有报错,没有任何异常,查也查不出什么问题。

Vue+Electron下Vuex的Dispatch没有效果怎么办

Vue+Electron下Vuex的Dispatch没有效果怎么办

网上的资料似乎也挺少。

折腾了很久,后来发现是 vuex-electron 里面一个插件的锅。

解决方法有两个。

方法一:

在 store/index.js 里面,就是上文特别强调了的那个文件,去掉 createSharedMutations 插件。

import Vue from 'vue'
import Vuex from 'vuex'
import { createPersistedState, createSharedMutations } from 'vuex-electron'
import modules from './modules'
Vue.use(Vuex)
export default new Vuex.Store({
 modules,
 plugins: [
 createPersistedState(),
 createSharedMutations() // 注释掉这一行
 ],
 strict: process.env.NODE_ENV !== 'production'
})

这是因为 vuex-electron 引入了一个用于多进程间共享 Vuex Store 的状态的插件。如果没有多进程交互的需求,完全可以不引入这个插件。

注释掉以后重启项目,用 this.$store.commit('XXX') 就可以使用了。
然而,如果需要多进程来处理怎么办?

方法二:

https://GitHub.com/vue-electron/vuex-electron#installation

看第 3 条:

In case if you enabled createSharedMutations() plugin you need to create an instance of store in the main process. To do it just add this line into your main process (for example src/main.js):
  import './path/to/your/store'

这种时候就不能用第一种方法来解决问题了。
好在文档也说了,加上一行导入。
找到 /src/main/index.js,在前面加上一句:

import '../renderer/store'

Vue+Electron下Vuex的Dispatch没有效果怎么办

之后一切正常,可以使用 Dispatch 来进行操作了。

Vue+Electron下Vuex的Dispatch没有效果怎么办

最后还有一个比较奇怪的问题:

Vue+Electron下Vuex的Dispatch没有效果怎么办

在直接调用 state 的时候,这样写 this.$store.state.loginStatus 是不行的,会 undefined,必须写成 this.$store.state.Auth.loginStatus,就像是 this.$store.state.Counter.main 一样,似乎可以解释为,不同的模块不指定名字的话就找不到。

但是,在写 Dispatch 的时候又不需要指定名字了,直接 dispatch('changeLoginStatus') 就行了,不然难道不应该是也按照 dispatch('Auth/changeLoginStatus') 这样子来写嘛……

关于“Vue+Electron下Vuex的Dispatch没有效果怎么办”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

--结束END--

本文标题: Vue+Electron下Vuex的Dispatch没有效果怎么办

本文链接: https://lsjlt.com/news/68045.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Vue+Electron下Vuex的Dispatch没有效果怎么办
    这篇文章将为大家详细讲解有关Vue+Electron下Vuex的Dispatch没有效果怎么办,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。这个问题是解决基于 vue 和...
    99+
    2024-04-02
  • php pcntl_signal没有效果怎么办
    本文操作环境:windows7系统、PHP7.1版、DELL G3电脑php pcntl_signal没有效果怎么办php的pcntl_signal用法及注意事项 最近需要做一个基于php的多进程server。为了优雅重启,需要捕获一...
    99+
    2016-10-11
    php pcntl_signal
  • react引入css没有效果怎么办
    本教程操作环境:Windows10系统、react18.0.0版、Dell G3电脑。react引入css没有效果怎么办?react 模块化引入外部css文件不生效问题处理react 中引入外部css/less文件时,如果直接引入 =》 i...
    99+
    2023-05-14
    React css
  • php配置没有生效怎么办
    本文操作环境:linux5.9.8系统、PHP7.2版、DELL G3电脑php配置没有生效怎么办?php重启后,配置不生效,一定要重新加载php.ini文件停止PHP:[root@jiang host]# pkill php-fpm查看9...
    99+
    2017-03-05
    php
  • vue页面转场效果没有生效是什么情况
    近年来,随着前端开发技术的不断发展,Vue作为一种流行的JS框架,受到越来越多的关注和使用。Vue提供了多种转场动画效果,可以让页面更加生动和美观。然而,有时我们在使用Vue进行开发时,会出现保存后页面没有转场的情况。那么,这个问题的原因是...
    99+
    2023-05-14
  • php exec函数没有生效怎么办
    本文操作环境:Windows7系统、PHP7.1版、DELL G3电脑php exec函数没有生效怎么办php.exec 不起作用解决办法第1.禁用方法如下: 打开/etc/php.ini文件, 查找到 disable_functions ...
    99+
    2020-08-27
    php exec
  • 下载的php7里没有php7 apache2_4.dll怎么办
    今天就跟大家聊聊有关下载的php7里没有php7 apache2_4.dll怎么办,可能很多人都不太了解,为了让大家更加了解,小编给大家总结了以下内容,希望大家根据这篇文章可以有所收获。具体问题:windows下安装php7,php7里面没...
    99+
    2023-06-25
  • vscode写vue没有高亮语法怎么办
    本教程操作环境:windows7系统、vue3&&Visual Studio Code 1.74.0版,DELL G3电脑。vscode设置vue语法高亮显示一、在编辑器中安装Vetur插件1.1 、打开vs code编辑器...
    99+
    2023-05-14
    Vue VSCode
  • vue中变量在settimeout内部效果失效怎么办
    这篇文章主要介绍了vue中变量在settimeout内部效果失效怎么办,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。解决方法如下:1、定义一...
    99+
    2024-04-02
  • win7电脑页面没有毛玻璃效果不变透明怎么办?
    大家知道Windows7启用了Aero效果,也就是毛玻璃效果,页面变透明,特别好看。这是我为什么一直爱上Windows7的原因,我觉得Windows7可以用到2025年没有问题。下面教大家一起变毛起来。 Mydriver...
    99+
    2023-06-14
    win7毛玻璃 win7毛玻璃主题 win7毛玻璃效果设置 win7电脑页面 效果 毛玻璃
  • Sublime执行后没有执行结果怎么办
    这篇文章主要介绍“Sublime执行后没有执行结果怎么办”,在日常操作中,相信很多人在Sublime执行后没有执行结果怎么办问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”Sublime执行后没有执行结果怎么办...
    99+
    2023-06-21
  • Win8提示以太网没有有效的ip配置怎么办
    这篇文章主要介绍Win8提示以太网没有有效的ip配置怎么办,文中介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们一定要看完!一、右击计算机,打开属性。二、进入设备管理器后,打开网络适配器。三、右击你的网卡,点击属性。四、点击高级,找到连...
    99+
    2023-06-28
  • FF与IE下CSS Padding效果不同怎么办
    这篇文章将为大家详细讲解有关FF与IE下CSS Padding效果不同怎么办,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。在Firefox与IE下CSS Padding效...
    99+
    2024-04-02
  • JPA默认值设置没有效果怎么解决
    这篇文章主要介绍“JPA默认值设置没有效果怎么解决”,在日常操作中,相信很多人在JPA默认值设置没有效果怎么解决问题上存在疑惑,小编查阅了各式资料,整理出简单好用的操作方法,希望对大家解答”JPA默认值设置没有效果怎么解决”的疑惑有所帮助!...
    99+
    2023-06-25
  • Vue怎么实现下拉框双向联动效果
    今天小编给大家分享一下Vue怎么实现下拉框双向联动效果的相关知识点,内容详细,逻辑清晰,相信大部分人都还太了解这方面的知识,所以分享这篇文章给大家参考一下,希望大家阅读完这篇文章后有所收获,下面我们一起来了解一下吧。一、前言在开发前端页面的...
    99+
    2023-06-29
  • vue打包完接口路径api没有了怎么办
    随着前端技术的不断发展,前端框架也在不断地改进和优化。目前比较流行的前端框架之一是Vue,Vue具有轻量级、易学易用等特点,受到了广大开发者的青睐。但是在使用Vue过程中,有些开发者遇到了一个问题:打包完之后,接口路径(api)消失了。那么...
    99+
    2023-05-14
  • Win8.1系统提示“以太网没有有效的ip配置”怎么办?
      Win8.1系统提示“以太网没有有效的ip配置”的解决方法: 1、点击任务栏右下角的“网络连接”图标,右键选择“打开网络和共享...
    99+
    2022-06-04
    以太网 提示 系统
  • DIV+CSS Padding在Firefox与IE下效果不同怎么办
    这篇文章将为大家详细讲解有关DIV+CSS Padding在Firefox与IE下效果不同怎么办,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。在Firefox与IE下DI...
    99+
    2024-04-02
  • 云服务器配置端口,并没有生效怎么办
    如果您的云服务器配置了端口,并且在使用过程中没有生效,可能有以下几种情况: 端口配置有误:如果您不熟悉云服务器端口的配置,最好联系云服务器的提供商,或者查询相关文档或者咨询相关技术人员。 未启用防火墙:如果您没有配置云服务器的防火墙,也...
    99+
    2023-10-26
    端口 服务器配置
  • 如何解决SEM推广怎么做都没有效果的问题
    本篇内容介绍了“如何解决SEM推广怎么做都没有效果的问题”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!  第一、关键词较差  这个问题其实很...
    99+
    2023-06-13
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作