This small helper library seamlessly combines HTMX with the latest Razor Components in the ASP.NET Core world. With this library, you can effortlessly return HTML through Minimal API endpoints, which is then rendered by Razor Components. Streamline development by harnessing the power of HTMX alongside the flexibility of Razor Components and Minimal APIs.
- Seamless integration of HTMX with Razor Components.
- Return HTML rendered by Razor Components via Minimal API endpoints.
- Accelerate the development of dynamic web applications in ASP.NET Core.
To use RazorHx in your ASP.NET Core project, you only need to install the NuGet package. Open your project in the Package Manager Console and run the following command:
Install-Package RazorHx
Alternatively, you can use the .NET CLI with the following command:
dotnet add package RazorHx
Here's a quick example of how to use the library:
var builder = WebApplication.CreateBuilder(args);
builder.Services.AddRazorHxComponents(options => {
options.RootComponent = typeof(RootLayout);
});
var app = builder.Build();
app.UseRazorHxComponents();
app.MapGet("/", () => new RazorHxResult<Hello>());
app.Run();
Create an endpoint which returns a RazorHxResult and append the WithOutOfBand extension to specify your oob component:
app.MapGet("/", () => new RazorHxResult<Hello>()
.WithOutOfBand<World>());
Define a slot in the DOM where the response will be swapped to:
<!-- Hello.razor or somewhere in Layouts -->
<div id="oob">
...
</div>
Lastly create a component which holds the content to swap in:
<!-- World.razor -->
<div id="oob" hx-swap-oob="true">
...
</div>
For a detailed changelog, please refer to the CHANGELOG.md file.
We welcome contributions and feedback on these planned features. If you have specific features you'd like to see or would like to contribute to the development, please check our contribution guidelines
This project is licensed under the MIT License.
Note: This library might still be in the development phase. We welcome your contributions and feedback!