Debug a Server–Side Rendered SAP Spartacus Storefront Using Chrome Dev Tools

In SAP Spartacus document there is a page for "How to Debug a Server–Side Rendered Storefront" using Visual Studio Code.

https://sap.github.io/spartacus-docs/3.x/how-to-debug-server-side-rendered-storefront/

This document just introduces another way to debug, using Chrome Dev Tools instead of Visual Studio Code.The steps are written based on Spartacus library with version 3.4.1.

(1) create a Storefront using Spartacus library and enable it with SSR support using Schematics,by following this document:

https://sap.github.io/spartacus-docs/3.x/building-the-spartacus-storefront-from-libraries-3-4/

(2) By default a script build:ssr is generated to build Storefront and launch it in SSR mode.

Debug a Server–Side Rendered SAP Spartacus Storefront Using Chrome Dev Tools

The build option --prod and production configuration is used so it means in this way you have to debug a version with minified and uglified code.

So we can create another script build:ssrdev with --prod and production configuration removed, so it comes with this content:

ng build && ng run mystore:server

Debug a Server–Side Rendered SAP Spartacus Storefront Using Chrome Dev Tools

In this way, check the bundles generated in folder server,we have un-minified source code which is easier for debugging now.

Debug a Server–Side Rendered SAP Spartacus Storefront Using Chrome Dev Tools

(3) add --inspect-brk option in node command in package.json file:

cross-env NODE_TLS_REJECT_UNAUTHORIZED=0 node --inspect-brk dist/mystore/server/main.js
Debug a Server–Side Rendered SAP Spartacus Storefront Using Chrome Dev Tools

npm run serve:ssr
Debug a Server–Side Rendered SAP Spartacus Storefront Using Chrome Dev Tools

(4) open chrome://inspect,press "inspect" hyperlink:

Debug a Server–Side Rendered SAP Spartacus Storefront Using Chrome Dev Tools

Then Chrome dev tools opens, with breakpoint stopped at the first line of main.js bundle, thanks to the --inspect-brk option:

Debug a Server–Side Rendered SAP Spartacus Storefront Using Chrome Dev Tools

Now we can debug at will. Press Ctrl + O and type the name of the file in which we would like to debug:

Debug a Server–Side Rendered SAP Spartacus Storefront Using Chrome Dev Tools

For example,if I would like to debug HTML tag generation process for SEO purpose, I can set breakpoint in file spartacus-storefront.js, class SeoMetaService.We can now just debug the Storefront running in SSR mode, just like the same when it is rendered using CSR ( Client Side Render ) mode.

Happy debugging!

Debug a Server–Side Rendered SAP Spartacus Storefront Using Chrome Dev Tools

更多Jerry的原创文章,尽在:"汪子熙":
Debug a Server–Side Rendered SAP Spartacus Storefront Using Chrome Dev Tools

上一篇:【Rust】枚举


下一篇:移动端开发在iOS系统中 new Date() 返回 NaN 的问题