Blazor.JSInteropPlus
1.0.0
dotnet add package Blazor.JSInteropPlus --version 1.0.0
NuGet\Install-Package Blazor.JSInteropPlus -Version 1.0.0
<PackageReference Include="Blazor.JSInteropPlus" Version="1.0.0" />
paket add Blazor.JSInteropPlus --version 1.0.0
#r "nuget: Blazor.JSInteropPlus, 1.0.0"
// Install Blazor.JSInteropPlus as a Cake Addin #addin nuget:?package=Blazor.JSInteropPlus&version=1.0.0 // Install Blazor.JSInteropPlus as a Cake Tool #tool nuget:?package=Blazor.JSInteropPlus&version=1.0.0
Easily Access Javascript Element Propertys and Functions trough C#
How to Install
Add the Nuget Package to your Solution
Install-Package Blazor.JSInteropPlus
Add the JavaScript File to your _Host.cshtml
<script src="_content/Blazor.JSInteropPlus/JSInteropPlus.js"></script>
Add the Namespace to your _Imports.razor
@using Blazor.Blazor.JSInteropPlus
How to Use
This Library exposes extensions Methods for the Original IJSRuntime Interface provided by Blazor.
Inject the IJSRuntime Interface to your Component
@inject IJSRuntime _jsRuntime
And use one of the Following extension Methods:
Propertys
Get the Value of a Property of a specific JS Element / Window
<div @ref=_divRef>...</div>
@code{
private ElementReference _divRef;
protected override async Task OnAfterRenderAsync(bool firstRender)
{
var width = await _jsInterop.GetElementPropertyAsync<double>(_divRef, "clientWidth");
//Or for the Window Object
var windowWidth = await _jsInterop.GetWindowPropertyAsync<double>("innerWidth");
}
}
Set the Value of a Property of a specific JS Element / Window
<div @ref=_divRef>...</div>
@code{
private ElementReference _divRef;
protected override async Task OnAfterRenderAsync(bool firstRender)
{
await _jsInterop.SetElementPropertyAsync(_divRef, "clientWidth", 500);
//Or for the Window Object
await _jsInterop.SetWindowPropertyAsync("name", "ThisIsMyNewName");
}
}
Methods
Call a Method a specific JS Element / Window
<div @ref=_divRef>...</div>
@code{
private ElementReference _divRef;
protected override async Task OnAfterRenderAsync(bool firstRender)
{
await _jsInterop.InvokeElementMethodAsync(_divRef, "scrollIntoView", {Optional Parameters});
//Or for the Window Object
await _jsInterop.InvokeWindowMethodAsync("print", {Optional Parameters});
}
}
Events
Subscribe to a Event of a specific Javascript Element /Window
<div @ref=_divRef>...</div>
@code{
private ElementReference _divRef;
protected override async Task OnAfterRenderAsync(bool firstRender)
{
await _jsRuntime.SubscribeToElementEventAsync(_divRef, "click", FunctionToCall, new JSEventOptions() { CallbackTime = TimeSpan.FromSeconds(1), CallbackType = Callback.Debounce });
//Or for the Window Object
await _jsRuntime.SubscribeToWindowEventAsync("blur", FunctionToCall, new JSEventOptions() { CallbackTime = TimeSpan.FromSeconds(1), CallbackType = Callback.Debounce });
}
private async Task FunctionToCall()
{
...
}
}
The Class 'JSEventOptions' is a Optional Parameter to Specify the behavior of the Callback, more down below.
Unsubscribe from a already subscribed Event of a specific Javascript Element /Window
<div @ref=_divRef>...</div>
@code{
private ElementReference _divRef;
protected async Task Unsubscribe()
{
await _jsRuntime.UnsubscribeFromElementEventAsync(_divRef, "click", FunctionToCall);
//Or for the Window Object
await _jsRuntime.UnsubscribeFromWindowEventAsync("blur", FunctionToCall);
}
private async Task FunctionToCall()
{
...
}
}
JSEventOptions
You can specify the behavior of JSEvent Callbacks:
public class JSEventOptions
{
/// <summary>
/// Specifies how the JS Event will invoke the C# Method
/// </summary>
public required Callback CallbackType { get; set; }
public TimeSpan CallbackTime { get; set; }
}
public enum Callback
{
/// <summary>
/// The C# Event will immediatly be triggered once the JS Event happens
/// </summary>
Instant,
/// <summary>
/// The C# Event will be triggered in a fixed interval
/// </summary>
Throttle,
/// <summary>
/// The C# Event will only be triggered if there are no more JS Events in a specified interval
/// </summary>
Debounce
}
License
Blazor.JSInteropPlus is MIT licensed.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net6.0 is compatible. net6.0-android was computed. net6.0-ios was computed. net6.0-maccatalyst was computed. net6.0-macos was computed. net6.0-tvos was computed. net6.0-windows was computed. net7.0 is compatible. net7.0-android was computed. net7.0-ios was computed. net7.0-maccatalyst was computed. net7.0-macos was computed. net7.0-tvos was computed. net7.0-windows was computed. net8.0 was computed. net8.0-android was computed. net8.0-browser was computed. net8.0-ios was computed. net8.0-maccatalyst was computed. net8.0-macos was computed. net8.0-tvos was computed. net8.0-windows was computed. net9.0 was computed. net9.0-android was computed. net9.0-browser was computed. net9.0-ios was computed. net9.0-maccatalyst was computed. net9.0-macos was computed. net9.0-tvos was computed. net9.0-windows was computed. |
-
net6.0
- Microsoft.AspNetCore.Components.Web (>= 6.0.3)
-
net7.0
- Microsoft.AspNetCore.Components.Web (>= 7.0.3)
NuGet packages
This package is not used by any NuGet packages.
GitHub repositories
This package is not used by any popular GitHub repositories.
Version | Downloads | Last updated |
---|---|---|
1.0.0 | 206 | 5/25/2023 |