Loading Boot Resources
controlling headers
Use middleware to control the headers collection:Program.cs
app.Use(async (context, next) =>
{
context.Response.Headers.Add("Content-Security-Policy", "{POLICY STRING}");
await next();
});
In hosted Blazor WASM apps, pass StaticFileOptions
to MapFallbackToFile
that specifies response headers:
Server project’s Program.cs
:
var staticFileOptions = new StaticFileOptions
{
OnPrepareResponse = context =>
{
context.Context.Response.Headers.Add("Content-Security-Policy",
"{POLICY STRING}");
}
};
...
app.MapFallbackToFile("index.html", staticFileOptions);
loading progress indicators
The Blazor WASM project template contains SVG and text indicators to show loading progress. These are implemented with HTML and CSS using two CSS custom properties provided by Blazor WASM:
--blazor-load-percentage
--blazor-load-percentage-text
To create custom indicators:
// resourcesLoaded is an instantaneous count of resources loaded during startup
// totalResources is the number of resources to load
const percentage = resourcesLoaded / totalResources * 100;
document.documentElement.style.setProperty('--blazor-load-percentage', `${percentage}%`);
document.documentElement.style.setProperty('--blazor-load-percentage-text', `"${Math.floor(percentage)}%"`);
The default round progress indicator is in wwwroot/index.html.
To implement a linear progress indicator:
wwwroot/css/app.css
.linear-progress {
background: silver;
width: 50vw;
margin: 20% auto;
height: 1rem;
border-radius: 10rem;
overflow: hidden;
position: relative;
}
.linear-progress:after {
content: '';
position: absolute;
inset: 0;
background: blue;
scale: var(--blazor-load-percentage, 0%) 100%; <!-- blazor-load-percentage is updated automatically -->
transform-origin: left top;
transition: scale ease-out 0.5s;
}