MinimalApis.LiquidViews 2.3.0

.NET 7.0
dotnet add package MinimalApis.LiquidViews --version 2.3.0
NuGet\Install-Package MinimalApis.LiquidViews -Version 2.3.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.3.0" />
For projects that support PackageReference, copy this XML node into the project file to reference the package.
paket add MinimalApis.LiquidViews --version 2.3.0
#r "nuget: MinimalApis.LiquidViews, 2.3.0"
#r directive can be used in F# Interactive, C# scripting and .NET Interactive. 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.3.0

// Install MinimalApis.LiquidViews as a Cake Tool
#tool nuget:?package=MinimalApis.LiquidViews&version=2.3.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 Versions
.NET net7.0 net7.0-android net7.0-ios net7.0-maccatalyst net7.0-macos net7.0-tvos net7.0-windows
Compatible target framework(s)
Additional computed target framework(s)
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.3.0 0 11/30/2022
2.2.16 140 9/21/2022
2.2.15 380 4/12/2022
2.2.14 231 1/13/2022
2.2.13 125 1/8/2022
2.2.12 130 1/7/2022
2.2.11 122 1/7/2022
2.2.10 127 1/7/2022
2.2.9 130 1/5/2022
2.2.8 363 12/9/2021
2.2.7 141 12/2/2021
2.2.6 145 12/1/2021
2.2.5 1,242 11/27/2021
2.2.4 2,893 11/25/2021
2.2.3 156 11/22/2021
2.2.2 916 11/20/2021
2.2.1 920 11/20/2021