Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/dotliquid/dotliquid
.NET Port of Tobias Lütke's Liquid template language.
https://github.com/dotliquid/dotliquid
Last synced: 6 days ago
JSON representation
.NET Port of Tobias Lütke's Liquid template language.
- Host: GitHub
- URL: https://github.com/dotliquid/dotliquid
- Owner: dotliquid
- License: other
- Created: 2010-08-19T01:50:46.000Z (over 14 years ago)
- Default Branch: master
- Last Pushed: 2024-12-05T03:19:20.000Z (about 1 month ago)
- Last Synced: 2025-01-02T12:05:15.988Z (13 days ago)
- Language: C#
- Homepage: https://www.dotliquid.org
- Size: 9.47 MB
- Stars: 1,065
- Watchers: 55
- Forks: 295
- Open Issues: 44
-
Metadata Files:
- Readme: README.markdown
- Changelog: CHANGELOG.markdown
- Contributing: contributing.md
- License: LICENSE.txt
Awesome Lists containing this project
- Awesome-Nuget-Packages - **DotLiquid**
README
# DotLiquid
[![DotLiquid tag on Stack Overflow](https://img.shields.io/badge/stackoverflow-dotliquid-orange.svg)](https://stackoverflow.com/questions/tagged/dotliquid)
[![AppVeyor Build](https://ci.appveyor.com/api/projects/status/xlev396hlh37s3to/branch/master?svg=true)](https://ci.appveyor.com/project/microalps/dotliquid/branch/master)
[![codecov](https://codecov.io/gh/dotliquid/dotliquid/branch/master/graph/badge.svg)](https://codecov.io/gh/dotliquid/dotliquid)
[![NuGet](https://img.shields.io/nuget/v/dotliquid.svg)](https://www.nuget.org/packages/dotliquid)
[![Gitter](https://badges.gitter.im/Join%20Chat.svg)](https://gitter.im/dotliquid/dotliquid?utm_source=badge&utm_medium=badge&utm_campaign=pr-badge&utm_content=badge)## Maintainers wanted
Have you sent a PR to this repository? In that case, would you consider getting
in touch with me so I can give you commit access to this repository? Please ping
me at [gitter/dotliquid](https://gitter.im/dotliquid/dotliquid) or here on
github.### What is this?
DotLiquid is a .Net port of the popular [Ruby Liquid templating
language](https://shopify.github.io/liquid/). It is a separate project that aims to
retain the same template syntax as the original, while using .NET coding
conventions where possible.For more information about the original Liquid project, see
.### Quick start
1. Download the latest release from [NuGet](https://www.nuget.org/packages/dotliquid).
2. Read the [docs](//github.com/dotliquid/dotliquid/wiki) for information
on writing and using DotLiquid templates.### Why should I use DotLiquid?
* You want to leave business logic in your compiled controllers and out of your templates.
* You're looking for a logic-less template language that also exists for other platforms (ie: node, python).
* You want to allow your users to edit their own page templates, but want to
ensure they don't run insecure code.
* You want to render templates directly from the database.
* You want a template engine for emails.### What does it look like?
``` liquid
-
{{product.name}}
Only {{product.price | price }}{{product.description | prettyprint | paragraph }}
{% for product in products %}
{% endfor %}
```
### How to use DotLiquid
DotLiquid supports a very simple API based around the DotLiquid.Template class.
Generally, you can read the contents of a file into a template, and then render
the template by passing it parameters in the form of a `Hash` object. There are
several ways you can construct a `Hash` object, including from a Dictionary, or
using the `Hash.FromAnonymousObject` method.
```c#
Template template = Template.Parse("hi {{name}}"); // Parses and compiles the template
template.Render(Hash.FromAnonymousObject(new { name = "tobi" })); // => "hi tobi"
```
### Projects using DotLiquid
Are you using DotLiquid in an open source project? Tell us with a PR!
- [Suave.DotLiquid](https://github.com/SuaveIO/suave#introduction)
- [Pretzel](https://github.com/Code52/Pretzel)
- [Docfx](https://github.com/dotnet/docfx)
- [DotLiquid.Mailer](https://github.com/miseeger/DotLiquid.Mailer)
- [DotLiquid Template Engine for Suave.IO](https://www.nuget.org/packages/Suave.DotLiquid/)
- [DotLiquid Template Engine for Giraffe](https://github.com/giraffe-fsharp/Giraffe.DotLiquid)
- [DotLiquid View Engine for ASP.NET MVC](https://www.nuget.org/packages/DotLiquid.ViewEngine)
- [DotLiquid View Engine for Nancy](https://www.nuget.org/packages/Nancy.Viewengines.DotLiquid)
- [GrandNode 2.0](https://github.com/grandnode/grandnode2)