MinimalApis.LiquidViews 2.8.0

dotnet add package MinimalApis.LiquidViews --version 2.8.0
NuGet\Install-Package MinimalApis.LiquidViews -Version 2.8.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="MinimalApis.LiquidViews" Version="2.8.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add MinimalApis.LiquidViews --version 2.8.0
#r "nuget: MinimalApis.LiquidViews, 2.8.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.
// Install MinimalApis.LiquidViews as a Cake Addin
#addin nuget:?package=MinimalApis.LiquidViews&version=2.8.0

// Install MinimalApis.LiquidViews as a Cake Tool
#tool nuget:?package=MinimalApis.LiquidViews&version=2.8.0

MinimalApis.LiquidViews

This library provides some extensions to ASP.NET Minimal APIs that allow to return templated view results using the Liquid language. Liquid is fast and safe. Views are interpreted so changes are reflected very quickly without a compilation phase.

This View Engine is based on Fluid, a Liquid template engine for .NET.

Sample usage

By default, all views and partials go in the Views folder. This can be configured with the FluidViewEngineOptions class.

These files demonstrate how to use the different elements of the view engine.

  • a Views\_layout.liquid file to act as a template for multiple pages.
  • a Views\_viewstart.liquid file to be executed for each view that is in the same folder.
  • a Views\component.liquid file to act like partial views.

The full sample can be found here

Program.cs
var builder = WebApplication.CreateBuilder(args);

// Add services to the container.

builder.Services.AddFluid();

var app = builder.Build();

// Configure the HTTP request pipeline.

app.MapGet("/", () => Results.Extensions.View("Index", new Todo(1, "Go back to work!", false)));

await app.RunAsync();

record Todo(int Id, string Name, bool IsComplete);
index.liquid
<hr />
Hello World from the body

Name: {{ Name }} <br />
IsComplete: {{ IsComplete}}
<hr />

{% section footer %}
Hello from the footer section
{% endsection %}
_viewstart.liquid
{% layout '_Layout' %}
component.liquid
<div>Using a component {{ x }} + {{ y }} = {{ x | plus: y }}</div>
_layout.liquid
<!doctype html>
<html lang="en">
  <head>
    <meta charset="utf-8">
    <title>Hello, world!</title>
  </head>
  <body>

    <h1>Title from the layout</h1>
    {% renderbody %}

    {% partial 'Component', x: 1, y:2 %}

    <footer>
      {% rendersection footer %}
    </footer>

  </body>
</html>

File locations

By default Views and Partials are located in the Views folder. The Partial views can also be placed in the Views/Partials folder.

Product Compatible and additional computed target framework versions.
.NET 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 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. 
Compatible target framework(s)
Included target framework(s) (in package)
Learn more about Target Frameworks and .NET Standard.

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
2.8.0 79 4/4/2024
2.7.0 91 3/18/2024
2.6.0 90 3/11/2024
2.5.0 1,079 9/28/2023
2.4.0 1,217 3/1/2023
2.3.1 419 12/17/2022
2.3.0 266 11/30/2022
2.2.16 396 9/21/2022
2.2.15 653 4/12/2022
2.2.14 460 1/13/2022
2.2.13 242 1/8/2022
2.2.12 238 1/7/2022
2.2.11 243 1/7/2022
2.2.10 255 1/7/2022
2.2.9 254 1/5/2022
2.2.8 470 12/9/2021
2.2.7 262 12/2/2021
2.2.6 265 12/1/2021
2.2.5 1,349 11/27/2021
2.2.4 2,993 11/25/2021
2.2.3 267 11/22/2021
2.2.2 1,033 11/20/2021
2.2.1 1,046 11/20/2021