什么,你还不会调试线上 vue 组件?
前言
彦祖们,在日常开发中,不知道你们是否遇到过这样的场景
在本地测试开发 vue
组件的时候非常顺畅
一上生产环境,客户说数据展示错误,样式不对...
但是你在本地测试了几次,都难以复现
定位方向
这时候作为老 vuer
,自然就想到了 vue devtools
但是新问题又来了,线上环境我们如何开启 vue devtools
呢?
案例演示
让我们以 element-ui
官网为例
先看下此时的 chrome devtools
是没有 Vue
的选项卡的
一段神奇的代码
其实很简单,我们只需要打开控制台,运行一下以下代码
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
线上问题调试,真的非常好用!
vue3
最近无意间又看到了这段代码,适配 vue3
亲测 vben
能用 https://vben.vvbin.cn/#/login?redirect=/dashboard
const el = document.querySelector('#app')
const vm = el.__vue_app__
window.__VUE_DEVTOOLS_GLOBAL_HOOK__.apps.push({
app: vm,
version: vm.version,
types: {
Comment: Symbol("Comment"),
Fragment: Symbol("Fragment"),
Static: Symbol("Static"),
Text: Symbol("Text"),
},
})
if (window.__VUE_DEVTOOLS_GLOBAL_HOOK__) {
window.__VUE_DEVTOOLS_GLOBAL_HOOK__.emit("init", vm);
console.log("==> vue devtools now is enabled");
}
写在最后
本次分享虽然没有什么技术代码,重在白嫖
感谢彦祖们的阅读
个人能力有限
分类:
前端
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· .NET10 - 预览版1新功能体验(一)
2019-02-25 java学习笔记-多线程