我有一些具有不可预测属性的对象,我想使用 Mustache.js 在电子邮件中呈现 HTML 内容以将其发送到我用户的电子邮件。这是我的代码:
在我的 HomeController
public ActionResult Index()
{
Person person = new Person
{
Name = "Dona",
Email = "dona3315@gmail.com",
};
PartialViewResult path = PartialView("PartialViewEmail");
string tmp = path.ViewName;
string resultRenderHtmlEmail = RenderRazorViewToString(tmp, person);
return View();
}
public ActionResult PartialViewEmail(Person model )
{
return PartialView(model);
}
public string RenderRazorViewToString(string viewName, object model)
{
ViewData.Model = model;
using (var sw = new StringWriter())
{
var viewResult = ViewEngines.Engines.FindPartialView(ControllerContext, viewName);
var viewContext = new ViewContext(ControllerContext, viewResult.View, ViewData, TempData, sw);
viewResult.View.Render(viewContext, sw);
viewResult.ViewEngine.ReleaseView(ControllerContext, viewResult.View);
return sw.GetStringBuilder().ToString();
}
}
这是我的 PartialViewEmal.cshtml
@model MvcApplication1.Models.Person
<script src="~/Scripts/mustache.js"></script>
<h1>This is razor partial view that demo for body of email</h1>
I'm @Model.Name and I'm @Model.Email years old.
<div id="sampleArea">
</div>
<script type="text/javascript">
$(function() {
var data = {
employees: [
{
firstName: "Christophe",
lastName: "Coenraets"
},
{
firstName: "John",
lastName: "Smith"
}
]
};
var template = "Employees:<ul>{{#employees}}" +
"<li>{{firstName}} {{lastName}}</li>" +
"{{/employees}}</ul>";
var html = Mustache.to_html(template, data);
$('#sampleArea').html(html);
});
</script>
这是 resultRenderHtmlEmail 的结果:
<script src="/Scripts/mustache.js"></script>
<h1>This is razor partial view that demo for body of email</h1>
I'm Dona and I'm dona3315@gmail.com years old.
<div id="sampleArea">
</div>
<script type="text/javascript">
$(function() {
var data = {
employees: [
{
firstName: "Christophe",
lastName: "Coenraets"
},
{
firstName: "John",
lastName: "Smith"
}
]
};
var template = "Employees:<ul>{{#employees}}" +
"<li>{{firstName}} {{lastName}}</li>" +
"{{/employees}}</ul>";
var html = Mustache.to_html(template, data);
$('#sampleArea').html(html);
});
</script>
它不理解 mustache.js !
我应该怎么办 ?
非常感谢 !