当前位置: 首页 > news >正文

浏览器开发者工具(尤其是 Vue Devtools 扩展)和 Vuex 的的订阅模式冲突

浏览器开发者工具(尤其是 Vue Devtools 扩展)和 Vuex 的的订阅模式冲突

  • 一、问题
  • 二、如何解决
      • 步骤 1:更新 / 重装 Vue Devtools 扩展(最优先)
      • 步骤 2:临时禁用 Vue Devtools 排除干扰
      • 步骤 3:检查 Vue 与 Vuex 版本兼容性
      • 步骤 4:清除浏览器缓存与无痕模式测试

一、问题

打开 F12(开发者工具)才报错,关闭则正常

报错如下:

#

二、如何解决

这种 “打开 F12(开发者工具)才报错,关闭则正常” 的现象,通常与 浏览器开发者工具(尤其是 Vue Devtools 扩展)和 Vuex 的交互逻辑 有关。核心原因是:打开 F12 时,Vue Devtools 会主动订阅 Vuex 的状态变化,若其添加的订阅者存在异常(或与你的代码冲突),就会触发 “sub is not a function” 错误。
具体原因分析

Vue Devtools(Vue 开发者工具扩展)为了在面板中展示 Vuex 的 action/mutation 执行记录,会通过 store.subscribe 或 store.subscribeAction 注册订阅者,监听 Vuex 的状态变化。当你打开 F12 时,Devtools 会激活并添加这些订阅者;关闭 F12 时,Devtools 的订阅者会被移除(或不激活),因此不会触发错误。

原因:
Vue Devtools 版本与 Vuex 版本不兼容:旧版本的 Devtools 可能不支持你当前使用的 Vuex 版本,导致其添加的订阅者格式错误(比如不是函数或有效对象)。

步骤 1:更新 / 重装 Vue Devtools 扩展(最优先)

90% 以上的此类问题源于 Vue Devtools 扩展版本过旧或与当前 Vuex 版本不兼容,按以下操作解决:

检查当前 Vue Devtools 版本:
打开 Chrome 浏览器 → 右上角菜单 → 更多工具 → 扩展程序 → 找到 “Vue.js devtools”,查看版本(建议至少 v6.0 以上)。

更新到最新版本:
进入Chrome 商店的 Vue Devtools 页面,点击 “更新”(若显示 “已添加”,先移除再重新安装)。

验证是否解决:
重新打开项目页面 → 打开 F12 → 检查是否还报错。若不报错,说明是旧版本扩展的兼容性问题,已解决。

步骤 2:临时禁用 Vue Devtools 排除干扰

若更新后仍报错,临时禁用扩展验证是否为扩展本身的问题:
进入浏览器扩展程序页面 → 关闭 “Vue.js devtools” 的开关(禁用扩展)。
刷新项目页面 → 打开 F12 → 观察是否报错。

若不报错:确认是 Vue Devtools 的问题(可能是扩展 bug),可等待扩展更新修复,或暂时使用其他浏览器(如 Edge)的最新扩展。

若仍报错:排除扩展影响,继续下一步。

步骤 3:检查 Vue 与 Vuex 版本兼容性

若 Vue、Vuex 版本不匹配,可能导致 Devtools 交互异常:
Vue 2 需搭配 Vuex 3.x(不兼容 Vuex 4.x);
Vue 3 需搭配 Vuex 4.x(不兼容 Vuex 3.x)。
验证版本:查看 package.json 中 vue 和 vuex 的版本,确保匹配(例如 vue: 2.6.x + vuex: 3.6.x)。若不匹配,卸载当前 Vuex 并安装对应版本:

//Vue 2 安装 Vuex 3.x
npm uninstall vuex
npm install vuex@3 --save
//Vue 3 安装 Vuex 4.x
npm uninstall vuex
npm install vuex@4 --save

步骤 4:清除浏览器缓存与无痕模式测试

若浏览器缓存了旧的 Vuex 状态或扩展数据,可能导致异常:
清除缓存:
打开 F12 → 切换到 “Application” 面板 → 左侧 “Storage” 下,右键点击 “Clear site data”(清除所有数据)。
无痕模式测试:
打开浏览器无痕模式(快捷键 Ctrl+Shift+N) → 禁用所有扩展 → 访问项目并打开 F12,观察是否报错(排除其他扩展或缓存干扰)。

按优先级执行:更新 Vue Devtools → 禁用扩展验证 → 检查代码中对 Vuex 内部属性的操作 → 验证版本兼容性。90% 的情况通过更新 / 禁用 Vue Devtools 即可解决,剩余情况多为代码中手动修改了 Vuex 内部订阅者列表,需按规范使用订阅注销函数。

http://www.dtcms.com/a/577161.html

相关文章:

  • 网站建设核电程序员找工作的网站
  • 特殊三列布局需求
  • js(DOM)基础:11、DOM定义、事件、文档的加载、DOM查询1、DOM实现轮播图、DOM查询2、DOM实现全选
  • 想做个电影网站该怎么做阳春ycqq人才招聘信息
  • JavaScript的Web APIs 入门到实战(day4):DOM 进阶与日期对象(附巩固练习和案例讲解)
  • AtCoder Educational DP Contest 刷题记录Ⅰ
  • WPF CalcBinding简化判断逻辑
  • HarmonyOS NFC应用开发:构建分布式近场通信解决方案
  • Robinhood的再进化:从零佣金交易到链上金融超级应用
  • Rust开发实战之简单游戏开发(piston游戏引擎)
  • MK9019 Buck降压电路设计笔记(光伏发电应用优化版 - UVLO 7V设置)
  • 5118网站的功能郑州网站优化公司排名
  • MQTT协议之QoS0(<=1)、QoS1(>=1)、QoS2(=1)详解
  • Dify使用02-Dify集成Ollama
  • [免费]基于Python的Flask酒店客房管理系统【论文+源码+SQL脚本】
  • LeetCode 219.存在重复元素2
  • 【CS224N】《深度学习自然语言处理》完整版笔记
  • 广东企业网站建设推荐网站做收录
  • XC7Z020-1CLG484I Xilinx AMD FPGA Zynq-7000 SoC
  • 论文分享 | BARD-GS:基于高斯泼溅的模糊感知动态场景重建
  • FPGA—ZYNQ学习spi(六)
  • 多智能体医疗会诊系统
  • ETCD 压力测试脚本
  • kali的下载和安装【ISO安装】
  • 从标签到数据流:BarTender让“可追溯”更简单
  • 零基础学AI大模型之Embedding与LLM大模型对比全解析
  • 7.游戏逆向-pxxx-TUObjectArray分析
  • web214-web220
  • 通州北苑网站建设程序开发的基本步骤是什么?
  • 专题:2025中国制造业出海与出海品牌社媒影响力洞察报告|附300+份报告PDF、数据、绘图模板汇总下载