Soenneker.Blazor.Utils.ModuleImport
4.0.1771
Prefix Reserved
See the version list below for details.
dotnet add package Soenneker.Blazor.Utils.ModuleImport --version 4.0.1771
NuGet\Install-Package Soenneker.Blazor.Utils.ModuleImport -Version 4.0.1771
<PackageReference Include="Soenneker.Blazor.Utils.ModuleImport" Version="4.0.1771" />
<PackageVersion Include="Soenneker.Blazor.Utils.ModuleImport" Version="4.0.1771" />
<PackageReference Include="Soenneker.Blazor.Utils.ModuleImport" />
paket add Soenneker.Blazor.Utils.ModuleImport --version 4.0.1771
#r "nuget: Soenneker.Blazor.Utils.ModuleImport, 4.0.1771"
#:package Soenneker.Blazor.Utils.ModuleImport@4.0.1771
#addin nuget:?package=Soenneker.Blazor.Utils.ModuleImport&version=4.0.1771
#tool nuget:?package=Soenneker.Blazor.Utils.ModuleImport&version=4.0.1771
Soenneker.Blazor.Utils.ModuleImport
A Blazor utility library assisting with asynchronous module loading
This library simplifies the process of loading JavaScript modules and provides methods for waiting until a module is loaded and disposing of modules when they are no longer needed.
Features
- Import JavaScript modules dynamically.
- Wait until a module is fully loaded.
- Dispose of JavaScript modules when they are no longer needed.
- Singleton pattern to ensure that each module is loaded only once.
Installation
To install, add the package to your Blazor project using the .NET CLI:
dotnet add package Soenneker.Blazor.Utils.ModuleImport
Register it in DI:
builder.Services.AddModuleImportUtil();
Example
Here's an example of how to use the ModuleImportUtil in a Blazor component:
@page "/example"
@inject IModuleImportUtil ModuleImportUtil
@implements IAsyncDisposable
<h3>Module Import Example</h3>
<button @onclick="LoadModule">Load Module</button>
@code {
private async Task LoadModule()
{
var module = await ModuleImportUtil.Import("exampleModule");
await ModuleImportUtil.WaitUntilLoaded("exampleModule");
// Guaranteed that the module has been added to the DOM, and available at this point
}
public async ValueTask DisposeAsync()
{
await ModuleImportUtil.DisposeModule("exampleModule");
}
}
| Product | Versions Compatible and additional computed target framework versions. |
|---|---|
| .NET | net10.0 is compatible. net10.0-android was computed. net10.0-browser was computed. net10.0-ios was computed. net10.0-maccatalyst was computed. net10.0-macos was computed. net10.0-tvos was computed. net10.0-windows was computed. |
-
net10.0
- Soenneker.Blazor.Utils.JsVariable (>= 4.0.1253)
- Soenneker.Dictionaries.Singletons (>= 4.0.33)
NuGet packages (16)
Showing the top 5 NuGet packages that depend on Soenneker.Blazor.Utils.ModuleImport:
| Package | Downloads |
|---|---|
|
Soenneker.Blazor.Utils.JsVariable
A Blazor interop library that checks (and waits) for the existence of a JS variable |
|
|
Soenneker.Blazor.Clarity
A small Blazor interop library that sets up Microsoft Clarity |
|
|
Soenneker.Blazor.LogJson
A Blazor interop library that logs JSON (like HTTP requests/responses) within the browser |
|
|
Soenneker.Blazor.ApplicationInsights
A Blazor interop library that sets up client-side Application Insights |
|
|
Soenneker.Blazor.MediaQuery
A Blazor interop library for media queries for viewport size logic |
GitHub repositories
This package is not used by any popular GitHub repositories.
| Version | Downloads | Last Updated |
|---|---|---|
| 4.0.1803 | 1,191 | 4/24/2026 |
| 4.0.1802 | 845 | 4/23/2026 |
| 4.0.1801 | 1,036 | 4/23/2026 |
| 4.0.1800 | 486 | 4/22/2026 |
| 4.0.1799 | 138 | 4/22/2026 |
| 4.0.1798 | 184 | 4/22/2026 |
| 4.0.1797 | 709 | 4/21/2026 |
| 4.0.1796 | 5,699 | 4/15/2026 |
| 4.0.1795 | 1,839 | 4/14/2026 |
| 4.0.1794 | 9,890 | 4/8/2026 |
| 4.0.1793 | 409 | 4/8/2026 |
| 4.0.1792 | 340 | 4/8/2026 |
| 4.0.1791 | 1,936 | 4/7/2026 |
| 4.0.1790 | 1,344 | 4/6/2026 |
| 4.0.1789 | 87 | 4/6/2026 |
| 4.0.1788 | 115 | 4/6/2026 |
| 4.0.1787 | 146 | 4/6/2026 |
| 4.0.1786 | 115 | 4/6/2026 |
| 4.0.1785 | 3,134 | 3/31/2026 |
| 4.0.1771 | 95 | 3/12/2026 |
improves CI