2011-05-23 110 views
16

我最近将项目从MVC 1升级到了MVC 3,现在我正在尝试使用Razor。关于Razor中嵌套代码块声明的问题

在一个视图中,我有一个foreach代码块,但嵌套的if语句似乎并不希望@在它的前面。

我原来的代码是:

@foreach(var r in Model.Results) 
{ 
    string css = r.Result.Count() > 0 ? "fail" : "pass"; 

    <p class="@css"><strong>@r.Description</strong></p> 

    @if(r.Result.Count() > 0) 
    { 
     <p>Count: @r.Result.Count()</p> 
     <table> 
      <thead> 
       <tr> 
        <th>ID</th><th>Title</th><th>Description</th> 
       </tr> 
      </thead> 
      <tbody> 
      @foreach(var e in r.Result) { 
       <tr><td>@e.Id</td><td>@e.Title</td><td>@e.Description</td></tr> 
      } 
      </tbody> 
     </table> 
    } 
} 

我会用@if一个运行时错误,上面写着:意外的“如果”关键字后,“@”字符。一旦进入代码,你不需要像“@”这样的结构前缀“if”。

如果我删除@代码运行良好。由于之前的HTML,我预计需要@。更让我困惑的是,在嵌套的foreach之前,我确实需要@。这里的规则是什么?

+0

这里有一个类似的问题,但我仍然不清楚@if和@foreach之间的区别。 http://stackoverflow.com/questions/4946334/razor-unexpected-foreach-keyword-after-character – Mattio 2011-05-23 15:48:19

回答

4

嵌套的foreach位于HTML内部(恰好在其他代码中)。

要从标记代码,您需要一个@
只有当直接嵌套代码块时才有必要。

+0

我认为这是明确的和衰退的 – gstar 2015-08-13 18:56:16

34

在剃须刀的任何圆括号内,它都需要一个匹配的开始和结束标签。这就是解析器的工作原理。

下面到目前为止的例子是有效的:

@for (var i = 0; i < 10; i++) { 
<p> 
    @i.ToString() 
</p> 
} 

这是不是:

@for (var i = 0; i < 10; i++) { 
<text> 
<p> 
    @i.ToString() 
</p> 
@if (i == 2) { 
<p>2</p> 
} 
</text> 
} 

@for (var i = 0; i < 10; i++) { 
<p> 
    @i.ToString() 
</p> 
@if (i == 2) { 
<p>2</p> 
} 
} 

为了解决这个问题,你可以在<text>块内等放置

所以在你的情况下,它会变成:

@foreach(var r in Model.Results) 
{ 
    @string css = r.Result.Count() > 0 ? "fail" : "pass"; 
<text> 

    <p class="@css"><strong>@r.Description</strong></p> 

    @if(r.Result.Count() > 0) 
    { 
    <p>Count: @r.Result.Count()</p> 
    <table> 
     <thead> 
      <tr> 
       <th>ID</th><th>Title</th><th>Description</th> 
      </tr> 
     </thead> 
     <tbody> 
     @foreach(var e in r.Result) { 
      <tr><td>@e.Id</td><td>@e.Title</td><td>@e.Description</td></tr> 
     } 
     </tbody> 
    </table> 
    } 
</text> 
} 
+2

哇,这不直观。有谁知道这是否是剃须刀中的错误? – 2015-05-04 06:19:23

+1

看看... https://weblogs.asp.net/scottgu/asp-net-mvc-3-razor-s-and-lt-text-gt-syntax – 2017-04-05 14:53:14