Razor.Templating.Core 1.7.0

There is a newer version of this package available.
See the version list below for details.
dotnet add package Razor.Templating.Core --version 1.7.0
                    
NuGet\Install-Package Razor.Templating.Core -Version 1.7.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="Razor.Templating.Core" Version="1.7.0" />
                    
For projects that support PackageReference, copy this XML node into the project file to reference the package.
<PackageVersion Include="Razor.Templating.Core" Version="1.7.0" />
                    
Directory.Packages.props
<PackageReference Include="Razor.Templating.Core" />
                    
Project file
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 Razor.Templating.Core --version 1.7.0
                    
#r "nuget: Razor.Templating.Core, 1.7.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.
#:package Razor.Templating.Core@1.7.0
                    
#:package directive can be used in C# file-based apps starting in .NET 10 preview 4. Copy this into a .cs file before any lines of code to reference the package.
#addin nuget:?package=Razor.Templating.Core&version=1.7.0
                    
Install as a Cake Addin
#tool nuget:?package=Razor.Templating.Core&version=1.7.0
                    
Install as a Cake Tool

<img src="https://raw.githubusercontent.com/soundaranbu/RazorTemplating/master/src/Razor.Templating.Core/assets/icon.png" width="70" height="70" />

Razor Templating

Build+Test Nuget Downloads Coverage

Using Razor for HTML templating was never been so easy like this. Render your .cshtml files into string easily using this library.

This project makes use of Razor SDK for precompiling the views.

Supported Application Types

.NET Core 3.0 .NET Core 3.1 .NET 5 .NET 6
Preferred Version v1.6.0 v1.6.0 v1.6.0 v1.7.0
Console
Api
Mvc
Worker Service
WPF
WinForms
Azure Functions

Supported View Features

MVC Razor View Features
ViewModel
ViewBag
ViewData
Layouts
ViewStarts
ViewImports
Partial Views
Tag Helpers
View Components (.NET 5 +)
Dependency Injection into Views

Applications

  • Email Templating
  • Report Generation & so on

Installing Nuget Package

This library is available as Nuget package

Using .NET CLI
dotnet add package Razor.Templating.Core
Using Package Reference .csproj
<PackageReference Include="Razor.Templating.Core" Version="1.7.0" />

Simple Usage:

using Razor.Templating.Core;

var model = new ExampleModel()
{
    PlainText = "This text is rendered from Razor Views using Razor.Templating.Core",
    HtmlContent = "<em>You can use it to generate email content, report generation and so on</em>"
};

var viewData = new Dictionary<string, object>();
viewData["Value1"] = "1";
viewData["Value2"] = "2";

var html = await RazorTemplateEngine.RenderAsync("/Views/ExampleView.cshtml", model, viewData);

Before applying this code, follow this article for working implementation: https://medium.com/@soundaranbu/render-razor-view-cshtml-to-string-in-net-core-7d125f32c79

Dependency Injection [Since v1.4.0]

Dependencies can be injected directly into views using @inject in .csthml file. Refer sample application here

In ASP.NET Core, add dependency like below in Startup.cs -> ConfigureServices

...
services.AddTransient<ExampleService>();
//add after registering all the dependencies
services.AddRazorTemplating();

or in console or other applications, add as below

using Microsoft.Extensions.DependencyInjection;

// Add dependencies to the service collection
var services = new ServiceCollection();
services.AddTransient<ExampleService>();
// Add RazorTemplating after registering all dependencies
// this is important for the razor template engine to find the injected services
services.AddRazorTemplating(); 
var html = await RazorTemplateEngine.RenderAsync("~/Views/ExampleViewServiceInjection.cshtml");

Razor Views in Library

Razor view files(.cshtml) can be organized in a separate shared Razor Class Libary(RCL). Sample library can be found here

Sample Applications

Please find the sample applications here

Note:

  • Please ensure that the views path is always unique among all the shared template projects.
References:

Thanks to all the great articles and projects which helped to bring this library out!

Product 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 was computed.  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.  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.
  • net6.0

    • No dependencies.

NuGet packages (25)

Showing the top 5 NuGet packages that depend on Razor.Templating.Core:

Package Downloads
Sitko.Core.App.Web

Sitko.Core is a set of libraries to help build .NET Core applications fast

FenixAlliance.ACL.Dependencies

Application Component for the Alliance Business Suite.

Bnsights.Core

Package Description

N3O.Umbraco.Blocks

TODO

Digizuite.Optimizely

The official integration between Digizuite DAM and Optimizely CMS.

GitHub repositories (2)

Showing the top 2 popular GitHub repositories that depend on Razor.Templating.Core:

Repository Stars
LANCommander/LANCommander
sitkoru/Sitko.Core
Sitko.Core is a set of libraries to help build .NET Core applications fast
Version Downloads Last Updated
2.1.0 766,051 10/14/2024
2.1.0-rc.1 1,677 9/12/2024
2.0.0 571,816 4/18/2024
2.0.0-rc.1 3,328 3/4/2024
1.9.0 903,211 8/25/2023
1.9.0-rc.2 112,693 2/25/2023
1.9.0-rc.1 229,722 11/13/2022
1.8.0 1,269,265 11/5/2022
1.8.0-rc.1 7,321 9/17/2022
1.7.1 577,744 7/2/2022
1.7.1-rc.1 14,363 2/20/2022
1.7.0 796,276 11/13/2021
1.7.0-preview.1 2,324 9/26/2021
1.6.1-rc.1 6,383 1/13/2022
1.6.0 488,454 9/26/2021
1.6.0-rc.2 8,283 5/14/2021
1.6.0-rc.1 1,605 5/13/2021
1.5.0 450,297 2/27/2021
1.4.0 124,468 12/5/2020 1.4.0 is deprecated.
1.4.0-rc.1 875 11/19/2020 1.4.0-rc.1 is deprecated.
1.3.0 9,263 11/17/2020 1.3.0 is deprecated.
1.2.1 42,960 9/21/2020 1.2.1 is deprecated.
1.2.0 4,175 7/11/2020 1.2.0 is deprecated.
1.1.2 3,729 4/13/2020 1.1.2 is deprecated.
1.1.0 1,281 4/13/2020 1.1.0 is deprecated.
1.0.1 1,319 4/3/2020 1.0.1 is deprecated.
1.0.0 6,024 4/3/2020 1.0.0 is deprecated.

- Added support for .NET 6