You signed in with another tab or window. Reload to refresh your session.You signed out in another tab or window. Reload to refresh your session.You switched accounts on another tab or window. Reload to refresh your session.Dismiss alert
Currently, all JavaScript and CSS assets are placed at the very bottom of the page. This used to be a "good practice" back in the days when defer scripts were not a thing. External script loading is blocking, so you want to defer them to the end of the page. Now we have defer scripts and defer CSS at our disposal, there is no such loading concern. By putting all resources at the bottom of the page, the browser is unaware of all these resources until it downloads and parse the entire document, which slows down the page load. By moving the assets to the head and assign them with the right fetchpriority, the browser can discover and kick of downloading all these assets in parallel for better page load perf, especially on large pages.
I am planning to move all the assets to the head, and mark all of them as defer. The process mainly involves refactoring assets.html and move it to the head at baseof.html
Code
Currently, all scripts files in the assets.html go through plugin/script.html for no good reason. This adds a level of unnecessary indirection, and plugin/script.html is difficult to maintain. Anyone trying to change anything here is first greeted with a long list of undocumented options you can pass into plugin/script.html. plugin/style.html has the similar problem.
I plan to refactor this part so that script tags are just script tags directly placed inside assets.html. We can always create small, reusable functions if needed.
SRI
The way SRI is implemented currently makes zero sense.
If the user chooses to enable fingerprint in the config, a fingerprint will be generated for files that are served locally. However, there is no way for the user to specify SRI for files from the CDN. This completely defeats the purpose of SRI. SRI for local files are useless, since if these files are tempered, the HTML files can be tempered too. While SRI is mainly used to check the integrity of files served from any third parties i.e. CDNs.
The plan is the change the format of jsdelivr.yml and how init.html parses the data.
and hopefully we can keep the backwards compatibility through the version identifier. And we will remove the fingerprint option and we do not generate SRI for local files.
The text was updated successfully, but these errors were encountered:
It might be impossible to render assets before the content. Some assets depend on toggles in shortcode or render hooks, which in turn depends on the content being rendered. Closing for now.
Location
Currently, all JavaScript and CSS assets are placed at the very bottom of the page. This used to be a "good practice" back in the days when defer scripts were not a thing. External script loading is blocking, so you want to defer them to the end of the page. Now we have defer scripts and defer CSS at our disposal, there is no such loading concern. By putting all resources at the bottom of the page, the browser is unaware of all these resources until it downloads and parse the entire document, which slows down the page load. By moving the assets to the head and assign them with the right
fetchpriority
, the browser can discover and kick of downloading all these assets in parallel for better page load perf, especially on large pages.I am planning to move all the assets to the head, and mark all of them as defer. The process mainly involves refactoring
assets.html
and move it to the head atbaseof.html
Code
Currently, all scripts files in the
assets.html
go throughplugin/script.html
for no good reason. This adds a level of unnecessary indirection, andplugin/script.html
is difficult to maintain. Anyone trying to change anything here is first greeted with a long list of undocumented options you can pass intoplugin/script.html
.plugin/style.html
has the similar problem.I plan to refactor this part so that script tags are just script tags directly placed inside
assets.html
. We can always create small, reusable functions if needed.SRI
The way SRI is implemented currently makes zero sense.
DoIt/layouts/partials/plugin/script.html
Lines 11 to 22 in 74e723e
If the user chooses to enable fingerprint in the config, a fingerprint will be generated for files that are served locally. However, there is no way for the user to specify SRI for files from the CDN. This completely defeats the purpose of SRI. SRI for local files are useless, since if these files are tempered, the HTML files can be tempered too. While SRI is mainly used to check the integrity of files served from any third parties i.e. CDNs.
The plan is the change the format of
jsdelivr.yml
and howinit.html
parses the data.DoIt/layouts/partials/init.html
Lines 31 to 42 in 74e723e
My proposed new format looks like
and hopefully we can keep the backwards compatibility through the version identifier. And we will remove the fingerprint option and we do not generate SRI for local files.
The text was updated successfully, but these errors were encountered: