0-1开发自己的obsidian plugin DAY 3

磨刀不误砍柴工

随着模块变多肉眼看不出问题了 于是先来解决一下debug配置的问题

之前只用过python的debug不知道typescript怎么搞,原来需要另外设置node.js的模式

主要参考的是:

https://www.youtube.com/watch?v=f3i9b3uK00U

预感踩坑开始,所以先新建了一个目录来实验一下,

新建一个src/main.ts放在上述目录下

然后cd到该目录运行:

npm install --save-dev ts-node tsconfig-paths

  • npm是 Node.js 的包管理器

  • ts-node是一个能让你(无需编译)直接运行.ts的执行器,

  • tsconfig-paths帮助Node.js理解typescript项目中的(类似src/ * 这样)的路径别名

这段代码运行以后可以看到*/node_modules/里生成了这两个对应的文件夹。

另外在项目目录下新建一个tsconfig.json,直接粘贴下面的内容。

bash 复制代码
{
"compilerOptions": {
"target": "es6",
"module": "commonjs",
"sourceMap": true // 开启 source map
}
}

这一步的目的是让断点和调试信息通过 sourceMap 文件映射回 TypeScript 文件

也就是说 ts-node 不显式生成 .js 文件,它会在后台动态编译你的 TypeScript 文件,是在开发阶段的一种调试。

最后就是回到vs code界面点那个侧边栏那个debug icon -> create a launch.json file -> node.js,打开配置launch.json, 粘贴下面内容:

bash 复制代码
{
    "version": "0.2.0",
    "configurations": [
        {
            "type": "node",
            "request": "launch",
            "name": "debug Program",
            "skipFiles": [
                "<node_internals>/**"
            ],
            "program": "${workspaceFolder}/src/main.ts",
            "runtimeArgs": ["-r", "ts-node/register","-r","tsconfig-paths/register"],
            "console":"integratedTerminal",
            "outFiles": [
                "${workspaceFolder}/**/*.js"
            ]
        }
    ]
}

这里的:

  • -r 是require的意思,表示在启动node.js前先加载(require)一个模块
  • 后面的参数就是前面生成的两个文件夹
  • console的配置使得能在vs code的终端看到的debug信息

最最后在代码里加断点,测试就可以看到成功了。

相关推荐
神の愛2 小时前
利用json-to-ts工具进行转换,放置在typeScript.ts文件中
javascript·typescript·json
zhensherlock4 小时前
Protocol Launcher 系列:Agenda 优雅组织你的想法与日程
javascript·macos·ios·typescript·node.js·mac·ipad
We་ct5 小时前
LeetCode 201. 数字范围按位与:位运算高效解题指南
开发语言·前端·javascript·算法·leetcode·typescript
梁山好汉(Ls_man)8 小时前
鸿蒙_关于自定义组件和自定义构建函数的个人理解
开发语言·华为·typescript·harmonyos·鸿蒙
阿珊和她的猫21 小时前
TypeScript 中的 `extends` 条件类型:定义与应用
javascript·typescript·状态模式
zero15971 天前
TypeScript 快速实战系列:基础入门|TypeScript 核心语法 1 小时吃透(必备基础)
javascript·typescript·大模型编程语言
落魄江湖行1 天前
入门篇二:Nuxt 4路由自动生成:告别手动配置路由的日子
前端·vue.js·typescript·nuxt4
条tiao条1 天前
不止语法糖:TypeScript Set 与 Map 深度解析
前端·javascript·typescript
zhensherlock1 天前
Protocol Launcher 系列:1Writer iOS 上的 Markdown 文档管理
javascript·笔记·ios·typescript·node.js·iphone·ipad
We་ct1 天前
LeetCode 137. 只出现一次的数字 II:从基础到最优的两种解法详解
前端·数据结构·算法·leetcode·typescript·位运算