Skip to content
文章目录

生产环境开启vue-devtools工具的方法

原理

vue devtools 扩展组件会在 window 全局注入 __VUE_DEVTOOLS_GLOBAL_HOOK__ 变量,Vue 就是根据这个变量判断是否需要调试的。

vue 根实例初始化之前判断 Vue.config.devtools 是否为 true。若为 true, 则调用 window.__VUE_DEVTOOLS_GLOBAL_HOOK__.emit('init', Vue) 方法初始化调试面板。

vue2 生产环境启用 Devtools

js
function openVueTool() {
  //在方法中执行,避免污染全局变量
  //开启vue2 production调试的方法

  //1.找vue实例,可以说99%的应用是用的app.__vue__
  //如果实在找不到,那么就到找到任意组件,用组件元素.__vue__.$root来获取
  var vue = app.__vue__

  //2.vue构造函数
  var constructor = vue.__proto__.constructor

  //3.Vue有多级,要找到最顶级的
  var Vue = constructor
  while (Vue.super) {
    Vue = Vue.super
  }
  console.log(Vue)

  //4.找到config,并且把devtools设置成true
  Vue.config.devtools = true

  //5.注册到Vue DevTool上
  var hook = window.__VUE_DEVTOOLS_GLOBAL_HOOK__
  hook.emit('init', Vue)

  //6.如果有vuex store,也注册//这部分代码参考了https://blog.csdn.net/weixin_34352449/article/details/91466542
  if (vue.$store) {
    var store = vue.$store
    store._devtoolHook = hook
    hook.emit('vuex:init', store)
    hook.on('vuex:travel-to-state', function (targetState) {
      store.replaceState(targetState)
    })
    store.subscribe(function (mutation, state) {
      hook.emit('vuex:mutation', mutation, state)
    })
  }
}

openVueTool()

vue3 生产环境启用 Devtools

js
var vue = app.__vue_app__
const hook = window['__VUE_DEVTOOLS_GLOBAL_HOOK__']
hook.emit('app:init', vue, vue.version, {
  Fragment: 'Fragment',
  Text: 'Text',
  Comment: 'Comment',
  Static: 'Static',
})

缺点

这个方法只是对当前标签页有效,就是说,如果你不小心(出于习惯)刷新了一下页面,或者有新标签页打开其他路由的需求,就需要重新走一遍上面的步骤。

长期解决方法

在浏览器安装Tampermonkey插件, 安装后点开插件的管理面板,新建一个脚本 粘贴下面的代码