最新公告
  • 欢迎您光临起源地模板网,本站秉承服务宗旨 履行“站长”责任,销售只是起点 服务永无止境!立即加入钻石VIP
  • 前端调试指南

    正文概述 掘金(王玉略)   2021-04-03   684

    背景

    日常开发中,面对日益复杂的工程和项目,难免会遇到一些问题和bug,很多同学(包括我自己)的第一反应是打个 log 看一下情况,然后逐步找原因。这种方式很有效,能解决很多问题,但是效率相对地下,并且不够专业。

    面对这种情况,笔者准备了一份前端调试指南,其中覆盖了日常开发中的大部分情况,例如:

    • 调试 javascript
    • 调试 node 服务
    • 调试 typescript
    • 调试 typescript 服务
    • 调试 typescript 前端项目

    如果读者对调试前端也有刚需,这份指南或许对你有用。为保证效果,建议读者边实践边阅读这份指南,调试代码的例子在这里

    前期准备

    环境: node:v14+ 编辑器:VS Code

    全局安装 nodemonts-nodeparcel

    yarn global add nodemon
    yarn global add ts-node
    yarn global add parcel
    
    # 安装依赖
    yarn
    

    tips: 下面例子中,例如 debug01,指的是 vscode 中的调试按钮,如下图:

    前端调试指南

    1、调试原生 node

    参考 demo01, 用 debug01 启动调试

    {
      "type": "node",
      "request": "launch",
      "name": "debug-01",
      "program": "${workspaceFolder}/demo01/index.js",
    }
    

    2、调试原生 node 服务

    express 为例:

    参考 demo02, 用 debug02 启动调试

    {
      "type": "node",
      "request": "launch",
      "name": "debug-02",
      "program": "${workspaceFolder}/demo02/index.js",
    }
    

    3、调试已启动的 node 服务

    express 为例:

    参考 demo02, 先用 node index.js 启动服务, 再用 debug02.1 开始调试

    {
      "type": "node",
      "request": "attach",
      "name": "debug-02.1",
      "processId": "${command:PickProcess}"
    }
    

    参考链接:

    VSCode 调试中 launch.json 配置不完全指南:调试已启动的 Node.js 程序

    4、过滤不想调试的文件

    参考 demo03, 用 debug03 启动调试

    {
      "type": "node",
      "request": "launch",
      "name": "debug-03",
      "program": "${workspaceFolder}/demo03/index.js",
      "skipFiles": [
        // 跳过 js 内部代码
        "<node_internals>/**",
        // 跳过指定文件代码
        "${workspaceFolder}/demo03/util.js"
      ],
    }
    

    参考链接:

    VS Code: Skipping uninteresting code

    5、调试 typescript

    参考 demo04, 用 debug04 启动调试

    (1)、第一步:编写 tsconfig.json 文件

    tsc 编译时会用到 tsconfig.json 配置文件

    {
      // 编译配置项
      "compilerOptions": {
        "allowSyntheticDefaultImports": true,
        // 输出文件夹
        "outDir": "out",
        // 编译生成 map 文件,这个配置对调试至关重要
        "sourceMap": true
      },
      // 需要编译的文件
      "files": [
        "./index.ts"
      ]
    }
    

    (2)、第二步:编写 launch.json 文件

    {
      "type": "node",
      "request": "launch",
      "name": "debug-04",
      "preLaunchTask": "build-demo04",
      "program": "${workspaceFolder}/demo04/index.ts",
      "outFiles": [
        "${workspaceFolder}/demo04/out/**/*.js"
      ],
    }
    

    注意这里新的配置参数:

    • preLaunchTask 表示在调试之前需要执行的任务,这个需要在 tasks.json 中编写,下面会讲到;
    • outFiles 表示 typescript 的源映射文件,只有正确配置好它,才能正常调试;

    (3)、第三步:编写 tasks.json 文件

    {
      "version": "2.0.0",
      "tasks": [
        {
          "label": "build-demo04",
          "type": "shell",
          "command": "cd demo04 && tsc"
        }
      ]
    }
    

    task 详细用法参考官方文档

    6、调试 typescript 服务

    参考 demo05, 用 debug05 启动调试

    7、typescript 动态更新

    参考 demo06, 借助 nodemon 的能力;这里写了 nodemon.json 配置文件,直接在 demo 目录下运行 nodemon 命令即可运行;

    参考链接:

    StackOverFlow: How to watch and reload ts-node when TypeScript files change

    8、调试 html 文件

    这需要借助 Debugger for Chrome 插件来调试,下载这个插件;

    参考 demo07, 用 debug07 启动调试

    {
      "type": "chrome",
      "request": "launch",
      "name": "debug-07",
      "file": "${workspaceFolder}/demo07/index.html"
    }
    

    9、调试前端项目

    这需要借助 Debugger for Chrome 插件来调试,下载这个插件;

    这个例子中用 parcel 来启动项目;

    参考 demo07

    进入 demo07, 用 parcel index.html --port 8899 启动项目,用 debug07.1 启动调试:

    {
      "type": "chrome",
      "request": "launch",
      "name": "debug-07.1",
      "url": "http://localhost:8899/index.html",
      "webRoot": "${workspaceFolder}/demo07"
    }
    

    10、调试 typescript 前端项目(由 parcel 启动)

    这个例子中用 parcel 来启动项目;

    这需要借助 Debugger for Chrome 插件来调试,下载这个插件;

    参考 demo08, 以 react 为例;

    进入 demo08,yarn 下载依赖,并用 parcel index.html --port 8899 启动项目,用 debug08 启动调试:

    {
      "type": "chrome",
      "request": "launch",
      "name": "debug-08",
      "url": "http://localhost:8899",
      "webRoot": "${workspaceFolder}/demo08",
      "sourceMapPathOverrides": {
        "../*": "${workspaceFolder}/demo08/*" // 或者:  "../*": "${webRoot}/*"
      }
    }
    

    注意上面的 sourceMapPathOverrides 字段,它表示源路径从 sourcemap 到这些源在磁盘上的位置的映射。当源代码不准确或者无法在构建过程中修复时,这种方法很有用。

    参考链接:

    VS Code: Debugger for Chrome

    Parcel Docs

    11、调试 typescript 前端项目(由 webpack 启动)

    这个例子中用 webpack 来启动项目;

    这需要借助 Debugger for Chrome 插件来调试,下载这个插件;

    参考 demo09, 以 react 为例;

    进入 demo09,yarn 下载依赖,并用 yarn start 启动项目,用 debug09 启动调试:

    {
      "type": "chrome",
      "request": "launch",
      "name": "debug-09",
      "url": "http://localhost:8899",
      "webRoot": "${workspaceFolder}/demo09",
      "sourceMapPathOverrides": {
        "webpack:///./~/*": "${webRoot}/node_modules/*", // Example: "webpack:///./~/querystring/index.js" -> "/Users/me/project/node_modules/querystring/index.js"
        "webpack:///./*": "${webRoot}/*", // Example: "webpack:///./src/app.js" -> "/Users/me/project/src/app.js",
        "webpack:///*": "*", // Example: "webpack:///project/app.ts" -> "/project/app.ts"
        "webpack:///src/*": "${webRoot}/*", // Example: "webpack:///src/app.js" -> "/Users/me/project/app.js"
      }
    }
    

    注意上面的 sourceMapPathOverrides 字段,参考自 VS Code: Debugger for Chrome 文档

    注意点:在 webpack 的配置中,需要设置 devtool: 'source-map'

    module.exports = merge(config, {
      mode: 'development',
      devtool: 'source-map', // 这里需要设置成 source-map 用来生成 map 文件
      devServer: {
        port: 8899
      }
    })
    

    起源地下载网 » 前端调试指南

    常见问题FAQ

    免费下载或者VIP会员专享资源能否直接商用?
    本站所有资源版权均属于原作者所有,这里所提供资源均只能用于参考学习用,请勿直接商用。若由于商用引起版权纠纷,一切责任均由使用者承担。更多说明请参考 VIP介绍。
    提示下载完但解压或打开不了?
    最常见的情况是下载不完整: 可对比下载完压缩包的与网盘上的容量,若小于网盘提示的容量则是这个原因。这是浏览器下载的bug,建议用百度网盘软件或迅雷下载。若排除这种情况,可在对应资源底部留言,或 联络我们.。
    找不到素材资源介绍文章里的示例图片?
    对于PPT,KEY,Mockups,APP,网页模版等类型的素材,文章内用于介绍的图片通常并不包含在对应可供下载素材包内。这些相关商业图片需另外购买,且本站不负责(也没有办法)找到出处。 同样地一些字体文件也是这种情况,但部分素材会在素材包内有一份字体下载链接清单。
    模板不会安装或需要功能定制以及二次开发?
    请QQ联系我们

    发表评论

    还没有评论,快来抢沙发吧!

    如需帝国cms功能定制以及二次开发请联系我们

    联系作者

    请选择支付方式

    ×
    迅虎支付宝
    迅虎微信
    支付宝当面付
    余额支付
    ×
    微信扫码支付 0 元