什么,你还不会调试线上 vue 组件?

前言

彦祖们,在日常开发中,不知道你们是否遇到过这样的场景

在本地测试开发 vue 组件的时候非常顺畅

一上生产环境,客户说数据展示错误,样式不对...

但是你在本地测试了几次,都难以复现

定位方向

这时候作为老 vuer,自然就想到了 vue devtools

但是新问题又来了,线上环境我们如何开启 vue devtools 呢?

案例演示

让我们以 element-ui 官网为例

先看下此时的 chrome devtools 是没有 Vue 的选项卡的

一段神奇的代码

其实很简单,我们只需要打开控制台,运行一下以下代码

js 复制代码
var Vue, walker, node;
walker = document.createTreeWalker(document.body,1);
while ((node = walker.nextNode())) {
  if (node.__vue__) {
    Vue = node.__vue__.$options._base;
    if (!Vue.config.devtools) {
      Vue.config.devtools = true;
      if (window.__VUE_DEVTOOLS_GLOBAL_HOOK__) {
        window.__VUE_DEVTOOLS_GLOBAL_HOOK__.emit("init", Vue);
        console.log("==> vue devtools now is enabled");
      }
    }
    break;
  }
}

显示 vue devtools now is enabled

证明我们已经成功开启了 vue devtools

功能验证

然后再重启一下 chrome devtool 看下效果

我们会发现此时多了一个 Vue 选项卡,功能也和我们本地调试一样使用

对于遇到 vue 线上问题调试,真的非常好用!

写在最后

本次分享虽然没有什么技术代码,重在白嫖

感谢彦祖们的阅读

个人能力有限

如有不对,欢迎指正 🌟 如有帮助,建议小心心大拇指三连🌟

相关推荐
PedroQue9912 小时前
uni-router v1.8.0新增冷启动守卫补执行
前端·uni-app
xiaok12 小时前
部署之后,本地浏览器还在读取旧缓存导致页面一直显示loading中
前端
用户0595401744612 小时前
Redis缓存一致性踩坑实录:线上故障排查6小时,我用pytest+内存快照把它永久关进了笼子
前端·css
星栈12 小时前
我用 Rust + Dioxus 做了个全栈跨平台笔记应用:第一版先把列表和详情跑通
前端·rust·前端框架
用户17335980753712 小时前
Vue 3 SPA 首屏优化:从 3s 到 1.2s 的 5 个实践
前端·vue.js
咖啡无伴侣12 小时前
基础骨架:30 分钟搭好 pnpm workspace,完成双项目 Monorepo 迁入
前端
谷无姜12 小时前
Webpack5 进阶思考:那些官方文档没讲清楚的事
前端·webpack
weedsfly12 小时前
还在用 Axios?你可能需要重新理解 XHR 与 Fetch
前端·javascript·面试
CoderWeen12 小时前
从零实现一个 Vue3 流程图编辑器:节点拖拽、贝塞尔连线与框选
前端·javascript
森鹿12 小时前
express中间件原理以及大致实现
前端·express