如何正确地逃避剃刀中的牙箍

时间:2011-04-07 22:57:30

标签: razor

尝试通过部分将模型对象渲染为JSON结构,如下所示:

@if( Model.IsEmpty ) {
    @( Model.UseNull ? "null" : "" )
} else {
    @{ int i = 0; }
    @foreach( var program in Model.Programs ) {
    <text>      
    @(++i > 1 ? "," : "" )
    {
        "Id": "@program.ProgramId",
        "Title": "@Html.Js( program.Title )",
        "Url": "@Html.Js( program.Url )",
    }
    </text>
    }
}

页面编译器在foreach行上抱怨,认为@符号是多余的。删除它会导致之前的行上的编译错误。如果我将if / else的整个部分括在<text>块中,它就会起作用。

除了使用显式文本部分之外,有没有办法提示编译器或转义大括号以避免这些错误?

2 个答案:

答案 0 :(得分:7)

在代码块中,您不能使用@个字符来创建更多代码块。

将您的代码更改为

@if( Model.IsEmpty ) {
    if (Model.UseNull) {
        @:null
    }
} else {
    int i = 0;
    foreach( var program in Model.Programs ) {
        if (++i > 1) {
            @:,
        }
        <text>      
            {
                "Id": "@program.ProgramId",
                "Title": "@Html.Js( program.Title )",
                "Url": "@Html.Js( program.Url )",
            }
        </text>
    }
}

但是,您应该使用JSON序列化程序。

答案 1 :(得分:3)

使用JavaScriptSerializer将模型对象转换为JSON可能比这种方法更好。

在我的项目中,我甚至把它变成了HtmlHelper,就像这样:

private static readonly JavaScriptSerializer JsonSerializer = new JavaScriptSerializer();
public static HtmlString ToJson<T> (this HtmlHelper htmlHelper, T obj)
{
    return new HtmlString(JsonSerializer.Serialize(obj));
}

然后您可以在视图中使用它,例如:

<script type="text/javascript">
    var model = @Html.ToJson(Model);
</script>