博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Visual Studio Code 断点调试 Vue
阅读量:7070 次
发布时间:2019-06-28

本文共 1735 字,大约阅读时间需要 5 分钟。

很多人习惯在 Chrome 的调试窗口中调试 Vue 代码, 或者直接使用 console.log 来观察变量值, 这是非常痛苦的一件事,需要同时打开至少 3 个窗体。个人还是更加习惯于断点调试。这篇文章将介绍如何配置 Visual Studio Code 和 Chrome 来完成直接在 VS Code 断点调试代码, 并且在VS Code的调试窗口看到Chrome中console相同的值。

设置 Chrome 远程调试端口

首先我们需要在远程调试打开的状态下启动 Chrome, 这样 VS Code 才能 attach 到 Chrome 上:

Windows

  • 右键点击 Chrome 的快捷方式图标,选择属性
  • 目标一栏,最后加上--remote-debugging-port=9222 注意要用空格隔开

macOS

  • 打开控制台执行:

    /Applications/Google\ Chrome.app/Contents/MacOS/Google\ Chrome --remote-debugging-port=9222

Linux

  • 打开控制台执行:

    google-chrome --remote-debugging-port=9222

Visual Stuido Code 安装插件

点击 Visual Studio Code 左侧边栏的扩展按钮, 然后在搜索框输入Debugger for Chrome并安装插件,再输入,安装完成后点击 reload 重启 VS Code

添加 Visual Studio Code 配置

  • 点击 Visual Studio Code 左侧边栏的 调试 按钮, 在弹出的调试配置窗口中点击 设置 小齿轮, 然后选择 chrome, VS Code 将会在工作区根目录生成.vscode 目录,里面会有一个 lanch.json 文件并会自动打开
  • 用下面的配置文件覆盖自动生成的 lanch.json 文件内容。

    {  // Use IntelliSense to learn about possible attributes.  // Hover to view descriptions of existing attributes.  // For more information, visit: https://go.microsoft.com/fwlink/?linkid=830387  "version": "0.2.0",  "configurations": [    {      "type": "chrome",      "request": "attach",      "name": "Attach to Chrome",      "port": 9222,      "webRoot": "${workspaceRoot}/src",      "url": "http://localhost:8080/#/",      "sourceMaps": true,      "sourceMapPathOverrides": {        "webpack:///src/*": "${webRoot}/*"      }    }  ]}

修改 webpack 的 sourcemap

如果你是基于 webpack 打包的 vue 项目, 可能会存在断点不匹配的问题, 还需要做些修改:

  • 打开根目录下的 config 目录下的 index.js 文件
  • dev 节点下的 devtool 值改为 'eval-source-map'
  • dev节点下的 cacheBusting 值改为 false

开始调试吧

一切具备了, 现在验收成果了

  • 通过第一步的方式以远程调试打开的方式打开 Chrome
  • 在 vue 项目中执行npm run dev以调试方式启动项目
  • 点击 VS Code 左侧边栏的调试按钮,选择 Attach to Chrome 并点击绿色开始按钮,正常情况下就会出现调试控制条。
  • 现在就可以在.vue文件的js代码中打断点进行调试了。
前往我的技术小站 查看更多博客。

转载地址:http://owell.baihongyu.com/

你可能感兴趣的文章
Git 标签操作
查看>>
linux 常用命令
查看>>
MeshLab中进行点云配准
查看>>
分布式搜索elasticsearch配置文件详解
查看>>
jquery api调用
查看>>
算法之美--读书笔记
查看>>
数据库Sharding的基本思想和切分策略
查看>>
WinForm------SimpleButton去掉点击时的边框
查看>>
关于Lisp和函数式编程 & 各种语言对比 & TIOBE
查看>>
Amazon AWS S3 操作手册
查看>>
用CSS设置Table的细边框的最好用的方法
查看>>
FPGA按键去抖verilog代码
查看>>
读书笔记 —— 《css秘密花园》
查看>>
win7 windows server 2008R2下 https SSL证书安装的搭配(搭配https ssl本地测试环境)
查看>>
086实战 项目开发流程,以及什么是数据分析平台,再者为什么要做数据分析平台,数据来源,数据处理流程...
查看>>
甲醛(Formaldehyde)
查看>>
gitlab
查看>>
中国科学院数学所二阶椭圆偏微分方程考博试题
查看>>
VUE --- 给页面加点网络动态数据
查看>>
Atitti 载入类的几种方法 Class.forName ClassLoader.loadClass 直接new
查看>>