Nustache - .NET 的无逻辑模板引擎
2024-12-14 09:21:33作者:温艾琴Wonderful
安装指南
通过 NuGet 安装
Nustache 可以通过 NuGet 包管理器进行安装。打开 Visual Studio 的包管理器控制台,输入以下命令:
Install-Package Nustache
如果你使用的是 MVC 项目,还需要安装 Nustache.Mvc3
包:
Install-Package Nustache.Mvc3
通过 GitHub 安装
你也可以从 GitHub 下载源代码并自行编译。步骤如下:
- 克隆或下载 Nustache 的 GitHub 仓库。
- 使用 Visual Studio 2012 或更高版本打开解决方案文件
Nustache.sln
。 - 编译项目,生成
Nustache.Core.dll
和Nustache.Mvc3.dll
(如果需要)。
项目的使用说明
非 MVC 项目
- 添加对
Nustache.Core.dll
的引用(如果你通过 NuGet 安装,这一步会自动完成)。 - 在代码中导入
Nustache.Core
命名空间。 - 使用
Render
类的静态方法来渲染模板。例如:
var html = Render.FileToString("foo.template", myData);
myData
可以是对象、IDictionary
或DataTable
。- 如果你需要更多的控制,可以使用
Render.Template
。
MVC 项目
- 添加对
Nustache.Mvc3.dll
的引用(如果你通过 NuGet 安装,这一步会自动完成)。 - 在
Global.asax.cs
中将NustacheViewEngine
添加到视图引擎列表中。例如:
ViewEngines.Engines.Add(new NustacheViewEngine());
- 参考
Nustache.Mvc3.Example
项目中的Global.asax.cs
文件获取更多示例。
命令行工具
Nustache 提供了一个命令行工具 nustache.exe
,用于从命令行渲染模板。使用方法如下:
nustache.exe foo.template myData.json foo.html
foo.template
是模板文件路径。myData.json
是数据文件路径,支持 JSON 或 XML 格式。foo.html
是输出文件路径。
项目 API 使用文档
核心 API
Render.FileToString(string templatePath, object data)
- 渲染指定路径的模板文件,并返回渲染后的字符串。
templatePath
:模板文件的路径。data
:用于渲染的数据,可以是对象、IDictionary
或DataTable
。
Render.Template
- 提供更灵活的模板渲染方式。你可以手动加载模板并进行渲染。例如:
var template = new Template();
template.Load(new StringReader(templateText));
var compiled = template.Compile<Foo>(null);
var html = compiled(fooInstance);
MVC API
NustacheViewEngine
- 用于在 ASP.NET MVC 项目中注册 Nustache 视图引擎。
ViewEngines.Engines.Add(new NustacheViewEngine());
辅助函数(Helpers)
Nustache 支持自定义辅助函数,用于在模板中执行自定义逻辑。例如:
Nustache.Core.Helpers.Register("FormatDateTime", FormatDateTime);
FormatDateTime
函数的实现如下:
static void FormatDateTime(RenderContext context, IList<object> arguments, IDictionary<string, object> options, RenderBlock fn, RenderBlock inverse)
{
if (arguments != null && arguments.Count > 0 && arguments[0] != null && arguments[0] is DateTime)
{
DateTime datetime = (DateTime)arguments[0];
if (options != null && options.ContainsKey("format"))
context.Write(datetime.ToString(options["format"] as string));
else
context.Write(datetime.ToString());
}
}
项目安装方式
Nustache 可以通过以下两种方式安装:
- NuGet 安装:推荐使用 NuGet 包管理器进行安装,方便快捷。
- GitHub 安装:从 GitHub 下载源代码并自行编译,适合需要进行二次开发的用户。
通过以上步骤,你可以轻松安装并使用 Nustache 模板引擎,无论是非 MVC 项目还是 MVC 项目,Nustache 都提供了简单易用的 API 和丰富的功能。
热门项目推荐
相关项目推荐
鸿蒙开发工具大赶集
本仓将收集和展示鸿蒙开发工具,欢迎大家踊跃投稿。通过pr附上您的工具介绍和使用指南,并加上工具对应的链接,通过的工具将会成功上架到我们社区。012hertz
Go 微服务 HTTP 框架,具有高易用性、高性能、高扩展性等特点。Go01每日精选项目
🔥🔥 每日精选已经升级为:【行业动态】,快去首页看看吧,后续都在【首页 - 行业动态】内更新,多条更新哦~🔥🔥 每日推荐行业内最新、增长最快的项目,快速了解行业最新热门项目动态~~029kitex
Go 微服务 RPC 框架,具有高性能、强可扩展的特点。Go00Cangjie-Examples
本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。Cangjie057毕方Talon工具
本工具是一个端到端的工具,用于项目的生成IR并自动进行缺陷检测。Python040PDFMathTranslate
PDF scientific paper translation with preserved formats - 基于 AI 完整保留排版的 PDF 文档全文双语翻译,支持 Google/DeepL/Ollama/OpenAI 等服务,提供 CLI/GUI/DockerPython06mybatis-plus
mybatis 增强工具包,简化 CRUD 操作。 文档 http://baomidou.com 低代码组件库 http://aizuda.comJava03国产编程语言蓝皮书
《国产编程语言蓝皮书》-编委会工作区018- DDeepSeek-R1探索新一代推理模型,DeepSeek-R1系列以大规模强化学习为基础,实现自主推理,表现卓越,推理行为强大且独特。开源共享,助力研究社区深入探索LLM推理能力,推动行业发展。【此简介由AI生成】Python00
热门内容推荐
最新内容推荐
项目优选
收起

Python - 100天从新手到大师
Python
610
115

本仓将收集和展示仓颉鸿蒙应用示例代码,欢迎大家投稿,在仓颉鸿蒙社区展现你的妙趣设计!
Cangjie
286
79

✍ WeChat Markdown Editor | 一款高度简洁的微信 Markdown 编辑器:支持 Markdown 语法、色盘取色、多图上传、一键下载文档、自定义 CSS 样式、一键重置等特性
Vue
111
25

旨在打造算法先进、性能卓越、高效敏捷、安全可靠的密码套件,通过轻量级、可剪裁的软件技术架构满足各行业不同场景的多样化要求,让密码技术应用更简单,同时探索后量子等先进算法创新实践,构建密码前沿技术底座!
C
60
48

🎉 基于Spring Boot、Spring Cloud & Alibaba、Vue3 & Vite、Element Plus的分布式前后端分离微服务架构权限管理系统
Vue
45
29

🦄🦄🦄AI赋能股票分析:自选股行情获取,成本盈亏展示,涨跌报警推送,市场整体/个股情绪分析,K线技术指标分析等。数据全部保留在本地。支持DeepSeek,OpenAI, Ollama,LMStudio,AnythingLLM,硅基流动,火山方舟,阿里云百炼等平台或模型。
Go
1
0

本仓将收集和展示高质量的仓颉示例代码,欢迎大家投稿,让全世界看到您的妙趣设计,也让更多人通过您的编码理解和喜爱仓颉语言。
Cangjie
205
57

前端智能化场景解决方案UI库,轻松构建你的AI应用,我们将持续完善更新,欢迎你的使用与建议。
官网地址:https://matechat.gitcode.com
376
36

🎉 基于SpringBoot,Spring Security,JWT,Vue & Element 的前后端分离权限管理系统,同时提供了 Vue3 的版本
Java
182
44

这是一个人工生命试验项目,最终目标是创建“有自我意识表现”的模拟生命体。
Java
8
0