如何找到 SAP Spartacus 里某个 Component TypeScript 编译后生成的 JavaScript 位置

需求

如何找到触发该网络请求的准确代码位置?

如何找到 SAP Spartacus 里某个 Component TypeScript 编译后生成的 JavaScript 位置_第1张图片

从 initiator 里查看调用栈上下文,一点头绪也没有。

如何找到 SAP Spartacus 里某个 Component TypeScript 编译后生成的 JavaScript 位置_第2张图片

找到触发该网络请求的控件的 selector:cx-register

如何找到 SAP Spartacus 里某个 Component TypeScript 编译后生成的 JavaScript 位置_第3张图片

在 Storefront TypeScript 源代码里查找不到:
如何找到 SAP Spartacus 里某个 Component TypeScript 编译后生成的 JavaScript 位置_第4张图片

在编译生成的 JavaScript 里搜索 cx-register:找到三处

如何找到 SAP Spartacus 里某个 Component TypeScript 编译后生成的 JavaScript 位置_第5张图片

只有直接查看 SAP Spartacus 源代码:cx-register 对应的 RegisterComponent,定义在 user-profile-components.module.ts 里:

如何找到 SAP Spartacus 里某个 Component TypeScript 编译后生成的 JavaScript 位置_第6张图片

最后找到了 RegisterComponent 里的其他依赖:
如何找到 SAP Spartacus 里某个 Component TypeScript 编译后生成的 JavaScript 位置_第7张图片

比如:

  • userRegister:UserRegisterFacade
  • globalMessageService:GlobalMessageService
  • fb:FormBuilder
  • router:RoutingService

这些依赖,在编译出来的 for 运行时代码里,都能够看见:
如何找到 SAP Spartacus 里某个 Component TypeScript 编译后生成的 JavaScript 位置_第8张图片

这些依赖都是作为另一个 module 被导入。

看不到这些 module 的方法里的 JavaScript 代码?

直接搜索 RegisterComponent,结果太多了有200多个匹配。

如何找到 SAP Spartacus 里某个 Component TypeScript 编译后生成的 JavaScript 位置_第9张图片

试试换成另一个方法:
如何找到 SAP Spartacus 里某个 Component TypeScript 编译后生成的 JavaScript 位置_第10张图片

找到了:

如何找到 SAP Spartacus 里某个 Component TypeScript 编译后生成的 JavaScript 位置_第11张图片

所以结论是,TypeScript 编译成的 JavaScript 源代码,运行时在 Chrome 开发者工具里还是能够找到的。
如何找到 SAP Spartacus 里某个 Component TypeScript 编译后生成的 JavaScript 位置_第12张图片

更多Jerry的原创文章,尽在:"汪子熙":

你可能感兴趣的:(如何找到 SAP Spartacus 里某个 Component TypeScript 编译后生成的 JavaScript 位置)