Scriban:高效、强大的.NET开源模板引擎,可用于邮件、文档生成!

现在前后端分离已经非常流行,我们已经很少关注模板生成引擎了。但在一些场景,比如邮件、文档生成,还是需要模板生成引擎的。

下面推荐一个轻量级且高效的文本模板生成引擎。

01 项目简介

Scriban是一个基于.NET的开源模板语言引擎,旨在简化文本生成任务。

Scriban主要功能与特性:

1、简洁的语法

该模板引擎使用简单、语法简洁。

例如,使用{{ variable }}输出变量,{% if condition %}...{% endif %}进行条件判断,{% for item in collection %}...{% endfor %}用于循环操作。

2、高性能

采用了编译到IL(中间语言)的方式,而非简单的字符串替换,这在处理大量数据时能够显著提升性能。

3、类型安全

Scriban能够利用静态类型检查,避免运行时错误,提高代码质量。

4、丰富的内置函数和过滤器

除了基本的变量和控制结构外,还提供了许多内置函数和过滤器,如字符串操作、日期格式化等,以增强模板的功能。

5、自定义标签和对象

允许开发者扩展其功能,创建自己的标签和对象,以满足特定需求。

6、兼容性与扩展性

Scriban具有用于解析Liquid模板的兼容模式,使得从Liquid迁移到Scriban变得容易。

7、跨平台

可以在Windows、Linux、MacOS等平台上运行。

02 使用方法

1、简单使用

复制代码
// 解析scriban 模板
var template = Template.Parse("Hello {{name}}!");

//结果:Hello World!
var result = template.Render(new { Name = "World" });

2、liquid模板

复制代码
// 解析 liquid 模板
var template = Template.ParseLiquid("Hello {{name}}!");

//结果:Hello World!
var result = template.Render(new { Name = "World" });

3、循环生成文本

复制代码
//循环模板
var template = Template.Parse(@"
<ul id='products'>
  {{ for product in products }}
    <li>
      <h2>{{ product.name }}</h2>
           Price: {{ product.price }}
           {{ product.description | string.truncate 15 }}
    </li>
  {{ end }}
</ul>
");
var result = template.Render(new { Products = this.ProductList });

03 项目地址

https://github.com/scriban/scriban

  • End -

推荐阅读

Asp.net动态Web API的教程!

Kiota:基于OpenAPI的HTTP客户端代码生成器

盘点下5个Winform UI开源控件库

Open-Xml-PowerTools:支持DOCX、PPTX、XLSX等文件的合并、拆分和互相转换的.Net开源工具

一个C#开源工具库,集成了超过1000个扩展方法

相关推荐
程序员cxuan5 小时前
虽迟但到!GPT-5.6 终于来了!
人工智能·后端·程序员
IT_陈寒7 小时前
React的这个渲染问题连官方文档都没说清楚
前端·人工智能·后端
葫芦和十三8 小时前
图解 MongoDB 15|journal 与持久化:写入怎么不丢,崩溃怎么恢复
后端·mongodb·面试
葫芦和十三8 小时前
图解 MongoDB 16|压缩:snappy、zstd 和 zlib 的取舍
后端·mongodb·面试
苍何8 小时前
终于找到免费开源TTS模型,克隆声音不要钱,本地电脑也能跑
后端
用户593608741409 小时前
Spring AI 集成 DeepSeek 原生供应商并实现think模式
后端
追逐时光者9 小时前
别再满网找零散工具了,腾讯 QQ 浏览器这个“帮小忙”工具箱真能省时间
前端·后端
心静自然凉8009 小时前
Linux网络核心知识+bonding主备模式配置
后端
爻渡11 小时前
异步编程演进史:从回调到Promise再到Async/Await
后端·程序员
要阿尔卑斯吗12 小时前
企业级 RAG 系统的文件标签管理:三层架构与层级优化实战
后端