当前位置: 代码网 > 科技>软件教程>编程开发 > 深入讲解VsCode各场景高级调试与使用技巧 代码编写效率提升2倍

深入讲解VsCode各场景高级调试与使用技巧 代码编写效率提升2倍

2023年12月22日 编程开发 我要评论
深入讲解VsCode各场景高级调试与使用技巧 代码编写效率提升2倍

{
  "version": "0.2.0",
  "configurations": [
    {
      "type": "chrome",
      "request": "launch",
      "name": "vuejs: chrome",
      "url": "http://localhost:8080",
      "webroot": "${workspacefolder}",
      "breakonload": true,
      "pathmapping": {
        "/_karma_jpgack_": "${workspacefolder}"
      },
      "sourcemappathoverrides": {
        "jpgack:/*": "${webroot}/*",
        "/./*": "${webroot}/*",
        "/src/*": "${webroot}/*",
        "/*": "*",
        "/./~/*": "${webroot}/node_modules/*"
      },
      "prelaunchtask": "serve"
    }
  ]
}
复制代码

添加任务脚本

{
  "version": "2.0.0",
  "tasks": [
    {
      "label": "serve",
      "type": "npm",
      "script": "serve",
      "isbackground": true,
      "problemmatcher": [
        {
          "base": "$tsc-watch",
          "background": {
            "activeonstart": true,
            "beginspattern": "starting development server",
            "endspattern": "compiled successfully"
          }
        }
      ],
      "group": {
        "kind": "build",
        "isdefault": true
      }
    }
  ]
}
复制代码

该脚本的作用是运行npm run serve编译命令。

f5启动调试即可

注意:此方式的主要点在于launch.json配置文件中,通过prelaunchtask字段指定调试前先运行一个任务脚本,prelaunchtask的值对应tasks.json文件中的label值。

借助vscode插件debugger for chrome在chrome中调试

  • 第一步还是初始化vue项目,添加vue.config.js文件配置,指定要生成sourcemaps资源
module.exports = {
  configurewebpack: {
    // 生成sourcemaps
    devtool: "source-map"
  }
};
复制代码

  • vscode中扩展中安装debugger for chrome插件,并确保没有禁用插件

  • 手动启动项目的运行, 此方式不需要配置tasks.json任务
# 终端执行命令,启动项目
npm run serve
复制代码

f5启动调试即可

借助vscode插件debugger for firfox在firefox中调试

  • debugger for chrome基本一样,区别在于安装debugger for firfox插件,并在launch.json配置中,增加调试firefox的配置即可,配置如下
{
  "version": "0.2.0",
  "configurations": [
    // 省略chrome的配置...
    // 下面添加的firefox的配置
    {
      "type": "firefox",
      "request": "launch",
      "reattach": true,
      "name": "vuejs: firefox",
      "url": "http://localhost:8080",
      "webroot": "${workspacefolder}/src",
      "pathmappings": [{ "url": "jpgack:///src/", "path": "${webroot}/" }]
    }
  ]
}
复制代码
  • 调试时选择对应的调试命令即可

firefox初始启动时不会触发调试,需要刷新一次

调试electron项目

electron很多人都使用过,主要用于开发跨平台的系统桌面应用。那么来看下vue-cli-electron-builder创建的electron项目怎么调试。步骤如下:

  • 在初始化项目后,首先修改vue.config.js文件配置,增加sourcemaps配置:
module.exports = {
  configurewebpack: {
    devtool: 'source-map'
  }
}
复制代码
  • 创建调试配置.vscode/launch.json

{
  "version": "0.2.0",
  "configurations": [
    {
      "name": "electron: main",
      "type": "node",
      "request": "launch",
      "protocol": "inspector",
      "prelaunchtask": "bootstarp-service",
      "runtimeexecutable": "${workspaceroot}/node_modules/.bin/electron",
      "windows": {
        "runtimeexecutable": "${workspaceroot}/node_modules/.bin/electron.cmd"
      },
      "args": ["--remote-debugging-port=9223", "./dist_electron"],
      "outfiles": ["${workspacefolder}/dist_electron/**/*.js"]
    },
    {
      "name": "electron: renderer",
      "type": "chrome",
      "request": "attach",
      "port": 9223,
      "urlfilter": "http://localhost:*",
      "timeout": 0,
      "webroot": "${workspacefolder}/src",
      "sourcemappathoverrides": {
        "jpgack:///./src/*": "${webroot}/*"
      }
    },
  ],
  "compounds": [
    {
      "name": "electron: all",
      "configurations": ["electron: main", "electron: renderer"]
    }
  ]
}
复制代码

此处配置了两个调试命令: electron: main用于调试主进程,electron: renderer用于调试渲染进程;compounds[].选项用于定义复合调试选项; configurations定义的复合命令是并行的; prelaunchtask用于配置命令执行前先执行的任务脚本,其值对应tasks.json中的label字段; prelaunchtask用在compounds时,用于定义configurations复合任务执行前先执行的脚本。

  • 创建任务脚本

{
  // see https://go.microsoft.com/fwlink/?linkid=733558
  // for the documentation about the tasks.json format
  "version": "2.0.0",
  "tasks": [
    {
      "label": "bootstarp-service",
      "type": "process",
      "command": "./node_modules/.bin/vue-cli-service",
      "windows": {
        "command": "./node_modules/.bin/vue-cli-service.cmd",
        "options": {
          "env": {
            "vue_app_env": "dev",
            "vue_app_type": "local"
          }
        }
      },
      "isbackground": true,
      "args": [
        "electron:serve", "--debug"
      ],
      "problemmatcher": {
        "owner": "custom",
        "pattern": {
          "regexp": ""
        },
        "background": {
          "beginspattern": "starting development server\\.\\.\\.",
          "endspattern": "not launching electron as debug argument was passed\\."
        }
      }
    }
  ]
}
复制代码
  • 启动调试

在主进程相关代码上打上断点,然后启动调试主进程命令就可以调试主进程了

注意,这里的options参数是根据实际的情况,自定义添加我们运行项目时所需要的参数,比如我这里因为启动项目的npm命令是:

"serve-local:dev": "cross-env vue_app_type=local vue_app_env=dev vue-cli-service electron:serve"
复制代码
  • 主进程调试成功

  • 开始调试渲染进程

切换到渲染进程的调试选项,在渲染进程的代码处打上断点,点击调试。注意,此时并不会有断点终端,需要ctrl+r手动刷新软件进程才会看到渲染进程的断点。

刷新渲染进程后的效果,如下图,已经进入了断点

另一种方式

同时开启渲染进程和主进程的调试,只需要切换到调试全部的选项即可。注意,此种方式因为compounds[].configurations配置是并行执行的,并不一定能保证渲染进程调试一定能附加到主进程调试成功(估计是时机问题),有些时候会调试渲染进程不成功。所以,可以采取上面的方式进行调试。

其他技巧

技巧一:代码片段(snippets)

从扩展商店中安装snippets

@category:"snippets"
复制代码

创建全局代码片段

  • 选择文件 -> 首选项 -> 用户片段
  • 选择新建全局代码片段文件

(0)

相关文章:

版权声明:本文内容由互联网用户贡献,该文观点仅代表作者本人。本站仅提供信息存储服务,不拥有所有权,不承担相关法律责任。 如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 2386932994@qq.com 举报,一经查实将立刻删除。

发表评论

验证码:
Copyright © 2017-2025  代码网 保留所有权利. 粤ICP备2024248653号
站长QQ:2386932994 | 联系邮箱:2386932994@qq.com