Not sure this is 100% accurate, but this seems to be close to how Power Pages rendering works. I needed a bit of a visual for myself, so, perhaps, it’ll help someone else, too:
data:image/s3,"s3://crabby-images/80616/806167a9c3e3bed90f6da39b5abd9eb28db050ac" alt=""
There are a few caveats there:
- What’s called “site header” is not, really, a header. It sort of is, but that part starts after the “standard” header that’s injected by PowerPages
- It’s the same with the footer, so you don’t need to include html and/or body tags, essentially your custom site header/footer templates are just parts of the html body
- Notice the use of “Header/Bottom” snippet there. It allows you to add some extra output to the head portion of the page ( you can find some other semi-hidden snippets in this git repo by the way: https://github.com/OOlashyn/PowerAppsPortalSiteSettingsAndSnippets )
However, if you create a page template and set it up so that it won’t be using site headers:
data:image/s3,"s3://crabby-images/cac70/cac70cd6bb158a693768d4769f071b8237e32e65" alt=""
Then it’s your web template that’s going to be responsible for the rendering from start to end, and the diagram above transforms into this:
data:image/s3,"s3://crabby-images/fc82f/fc82fc02336c9bc528bf2d2499eac1fa6078226d" alt=""
In which case you have full control, but you may inadvertently lose something that Power Pages would automatically inject there otherwise.