AugusteVN.Razor.StateChange
1.1.0
dotnet add package AugusteVN.Razor.StateChange --version 1.1.0
NuGet\Install-Package AugusteVN.Razor.StateChange -Version 1.1.0
This command is intended to be used within the Package Manager Console in Visual Studio, as it uses the NuGet module's version of Install-Package.
<PackageReference Include="AugusteVN.Razor.StateChange" Version="1.1.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="AugusteVN.Razor.StateChange" Version="1.1.0" />
<PackageReference Include="AugusteVN.Razor.StateChange" />
For projects that support Central Package Management (CPM), copy this XML node into the solution Directory.Packages.props file to version the package.
paket add AugusteVN.Razor.StateChange --version 1.1.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
#r "nuget: AugusteVN.Razor.StateChange, 1.1.0"
#r directive can be used in F# Interactive and Polyglot Notebooks. Copy this into the interactive tool or source code of the script to reference the package.
#addin nuget:?package=AugusteVN.Razor.StateChange&version=1.1.0
#tool nuget:?package=AugusteVN.Razor.StateChange&version=1.1.0
The NuGet Team does not provide support for this client. Please contact its maintainers for support.
StateChangeProvider
Notify whenever the value of a property in our Blazor global state changes.
Usage
Inheritance only.
public class BlogHttpClient : StateChangeProvider
{
private BlogPostResponse? _selectedBlogPost;
public BlogPostResponse? SelectedBlogPost {
get => _selectedBlogPost;
set => SetField(ref _selectedBlogPost, value);
}
private readonly HttpClient _http;
public BlogHttpClient(HttpClient http)
{
_http = http;
}
public async Task InitSelectedBlogPost(GetBlogPostForSlugRequest request)
{
SelectedBlogPost = await GetBlogPostForSlug(request);
}
private async Task<BlogPostResponse?> GetBlogPostForSlug(GetBlogPostForSlugRequest request)
{
try
{
return await _http.GetFromJsonAsync<BlogPostResponse>($"{ApiRoutes.BlogPosts}/{request.Slug}");
}
catch (Exception e)
{
_logger.LogWarning("Could not get blog post with slug: {slug}, {@errorMessage}", request.Slug, e.Message);
return null;
}
}
}
Manual Notification
public class BlogHttpClient : StateChangeProvider
{
private BlogPostResponse? _selectedBlogPost;
public BlogPostResponse? SelectedBlogPost {
get => _selectedBlogPost;
set => SetField(ref _selectedBlogPost, value);
}
public void UpdateBlogPost(BlogPostResponse blogPost) {
SelectedBlogPost = new BlogPostResponse { ... }; // Should trigger change notification.
// But
SelectedBlogPost.Authors = new List<Author> {...}; // Might not trigger due to nesting etc.
// So trigger manually.
NotifyPropertyChanged(nameof(SelectedBlogPost));
}
}
Property Change Notifications
ExampleComponent.razor
@implements IDisposable
@inject BlogHttpClient BlogHttpClient
@code {
protected override void OnInitialized()
{
BlogHttpClient.PropertyChanged += HandleStateChanged;
}
private void HandleStateChanged(object? sender, PropertyChangedEventArgs e)
{
if (e.PropertyName == nameof(BlogHttpClient.SelectedBlogPost))
{
Console.WriteLine(BlogHttpClient.SelectedBlogPost.Title);
}
}
public void Dispose()
{
State.PropertyChanged -= HandleStateChanged;
}
}
To see it in action, watch: Event-Driven Programming with Blazor in C# .NET 8.
Brought to you by: kiss-code.com.
Product | Versions Compatible and additional computed target framework versions. |
---|---|
.NET | net8.0 is compatible. 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. net10.0 was computed. 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. |
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.
-
net8.0
- Microsoft.AspNetCore.Components.Web (>= 8.0.0)
NuGet packages (1)
Showing the top 1 NuGet packages that depend on AugusteVN.Razor.StateChange:
Package | Downloads |
---|---|
AugusteVN.Razor.State
Helper classess and components for state management. |
GitHub repositories
This package is not used by any popular GitHub repositories.
Remove PropertyChanged component.