One of my colleagues today asked me this question: Suppose this below is an application generated by Smart Template, and I would like to debug how the back button is implemented. Since the whole UI page is implemented by framework, I don’t know where to set breakpoint. How to proceed?
data:image/s3,"s3://crabby-images/34e31/34e3194b24980a9efcc60dfa2a8031dde088f559" alt=""
Here below is my process about how to find the back implementation in framework file within several minutes.
(1) Use Chrome extension Inspector ( the UI5 tab in Chrome development tool below ) to figure out that the button is located in UI area sap.uxap.ObjectPageHeader.
data:image/s3,"s3://crabby-images/31991/31991869c7df9f110437bde6ebe95611a56d768d" alt=""
Based on the learning in My understanding about how object page in Smart Template is rendered I search by keyword “Back” in file Details.view.xml first, no result.
data:image/s3,"s3://crabby-images/7cfbb/7cfbbc6fb149bf9cd7d6a7e891d3092ed69fe776" alt=""
(2) Then search in next xml file NavigationBar.fragment.xml, this time the button is found.
data:image/s3,"s3://crabby-images/03f27/03f27261c1883b317163ad21f457b0eb49d2092f" alt=""
Perform global search via Ctrl+Shift+F with key word “_templateEventHandlers.onBack“, no result.
data:image/s3,"s3://crabby-images/d731a/d731a16ecf3d8eb12bbb0a8a9d244ff5a40774ec" alt=""
Then search “_templateEventHandlers” instead, this time TemplateAssembler-dbg.js is found.
data:image/s3,"s3://crabby-images/4ae90/4ae903c35045a3fdc18730a847a1f5f12c3ed747" alt=""
Unfortunately it is difficult to judge the type of _templateEventHandlers simply from context code as it is filled in a generic way.
data:image/s3,"s3://crabby-images/8b895/8b895c4062c2855faca38aa92443e7f27f0582e0" alt=""
(3) Perform search on onBack instead, and the result is what I am looking for:
data:image/s3,"s3://crabby-images/3492d/3492dc8dfeb43fb7140356d09556973fb484ccc1" alt=""
Set a breakpoint and click back button to verify: breakpoint is triggered:
data:image/s3,"s3://crabby-images/5723e/5723e067fbf4c3dff78de607e20e4b6c5c1731d7" alt=""
So the trick here is the keyword I am using to search in a tentative way.
- first time search by _templateEventHandlers.onBack, no result
- second time search by _templateEventHandlers, has result but not useful
- third time search by onBack, done.
网友评论