
























在 .NET 开发中,生成 HTML 内容是一个常见的需求。无论是构建邮件模板、生成报表、还是创建动态网页内容,我们都需要一种简洁、安全且高效的方式来构建 HTML。今天,我想向大家介绍 Jasmine.Format —— 一个专为高性能场景设计的 .NET HTML 生成库。
传统的 HTML 字符串拼接方式存在以下问题:
Jasmine.Format 旨在解决这些问题,提供一个流畅、安全、高效的 HTML 生成解决方案。
var p = new HtmlP().Add("<script>alert('XSS')</script>");
// 输出: <p><script>alert('XSS')</script></p>
所有通过 Add() 方法添加的文本都会自动进行 HTML 编码,有效防止 XSS 攻击。只有在明确信任内容时,才使用 AddRaw() 方法。
var html = new HtmlP()
.Add("您好,")
.Add(new HtmlSpan("张三", "#0066cc"))
.Add("!欢迎使用系统。")
.WithStyle("font-size: 14px; line-height: 1.5;")
.ToHtml();
// 输出: <p style="font-size: 14px; line-height: 1.5;">您好,<span style="color:#0066cc;">张三</span>!欢迎使用系统。</p>
链式方法调用让代码简洁直观,易于阅读和维护。
var original = new HtmlP().Add("原始内容");
var modified = original.Add("新增内容");
// original 保持不变
Console.WriteLine(original.ToHtml()); // <p>原始内容</p>
Console.WriteLine(modified.ToHtml()); // <p>原始内容新增内容</p>
每次操作返回新实例,原始实例保持不变。这种不可变设计使得对象可以在多线程环境下安全共享,无需任何同步机制。
// 对象池配置
private static readonly ObjectPool<List<object>> _listPool =
new ObjectPool<List<object>>(() => new List<object>(), 32);
支持 .NET Standard 2.0、.NET 6/7/8/9/10,可在各种 .NET 项目中使用。
dotnet add package Jasmine.Format
using Jasmine.Format;
using Jasmine.Format.Elements.Text;
using Jasmine.Format.Elements.Basic;
// 简单段落
var p = new HtmlP().Add("Hello, World!");
// 带样式的段落
var p = new HtmlP().Add("内容").WithStyle("text-align: center;");
// 混合内容
var p = new HtmlP()
.Add("访问 ")
.Add(new HtmlA("示例网站", "https://example.com", "_blank"))
.Add(" 了解更多");
using Jasmine.Format.Elements.List;
// 无序列表
var ul = new HtmlList(ListType.Unordered)
.AddItem("项目一")
.AddItem("项目二")
.AddItem("项目三");
// 有序列表(从 5 开始)
var ol = new HtmlList(ListType.Ordered, 5)
.AddItem("第五步")
.AddItem("第六步");
// 批量添加
var items = new[] { "A", "B", "C" };
var ul = new HtmlList(ListType.Unordered).AddRange(items);
using Jasmine.Format.Elements.Container;
var div = new HtmlDiv("border: 1px solid #ccc; padding: 10px;")
.Add(new HtmlP().Add("标题"))
.Add(new HtmlP().Add(new HtmlSpan("高亮文本", "#ff6600")));
var isAdmin = true;
var p = new HtmlP()
.Add("用户:")
.Add(userName)
.Add(isAdmin ? " (管理员)" : "");
var trains = new[] {
new { Station = "北京", TrainNo = "G123", Status = "正常" },
new { Station = "上海", TrainNo = "G456", Status = "晚点" }
};
var p = new HtmlP()
.Add("列车信息:")
.AddSpanRange(trains, t => new HtmlSpan(
$"{t.Station}开{t.TrainNo}次",
t.Status == "正常" ? "green" : "red"
));
using Jasmine.Format.Utilities;
// 位置参数
var html = HtmlFormatHelper.Format(
"欢迎 {0}, 年龄: {1}",
"张三", "25"
);
// 命名参数
var dict = new Dictionary<string, string>
{
{ "name", "李四" },
{ "age", "30" }
};
var html = HtmlFormatHelper.FormatTemplate(
"姓名: {name}, 年龄: {age}",
dict
);
在内部测试中,Jasmine.Format 在高并发场景下表现优异:
| 测试场景 | 传统字符串拼接 | Jasmine.Format |
|---|---|---|
| 1000 次循环生成 | ~15ms | ~8ms |
| 内存分配次数 | ~2000 次 | ~500 次 |
| 多线程并发 | 需要同步 | 无需同步 |
var emailBody = new HtmlDiv("font-family: Arial;")
.Add(new HtmlP().Add($"尊敬的 {userName}:"))
.Add(new HtmlP().Add("您的订单已发货,详情如下:"))
.Add(new HtmlList(ListType.Unordered)
.AddRange(orderItems.Select(i => $"{i.Name} - {i.Price}元")))
.ToHtml();
var report = new HtmlDiv()
.Add(new HtmlP($"报告日期:{DateTime.Now:yyyy-MM-dd}").WithStyle("font-weight: bold;"))
.Add(new HtmlList(ListType.Ordered)
.AddRange(summaryItems))
.ToHtml();
var notification = new HtmlP()
.Add(new HtmlSpan("系统通知", "#ff6600", "font-weight: bold;"))
.AddRaw("<br/>")
.Add(messageContent)
.ToHtml();
AddRaw()AddSpanRange、AddRange 等方法处理集合数据Jasmine.Format 是一个开源项目,欢迎社区贡献:
Jasmine.Format 提供了一种简洁、安全、高效的方式来生成 HTML 内容。它的不可变设计确保了线程安全,自动编码防止了 XSS 攻击,对象池优化提升了性能。如果你在 .NET 项目中需要生成 HTML,不妨试试 Jasmine.Format!
相关链接:
技术栈:
此内容由惯性聚合(RSS阅读器)自动聚合整理,仅供阅读参考。 原文来自 — 版权归原作者所有。