Razor complains when I put a closing div tag in a if clause

前端 未结 1 874
伪装坚强ぢ
伪装坚强ぢ 2021-02-12 11:47

I am trying to do this using Razor templating:

@if(isNew)
{
   
} ... @if(isNew) {
}

The error is:<

相关标签:
1条回答
  • 2021-02-12 12:04

    Razor doesn't like it when you split start/end tags up like this as it can't parse the HTML properly, so you have to escape them as plain text:

    @if(isNew)
    {
       @:<div class="new">
    }
    
    ...
    
    
    @if(isNew)
    {
       @:</div>
    }    
    

    The more conventional approach would be to repeat the markup inside the div (using partials or otherwise) - which approach is more desirable, I would say, is dependent upon the nature of the markup in between the conditional divs:

    @if(isNew)
    {
        <div class="new">
            <!-- some markup or partial view -->
        </div>
    }
    else
    {
        <!-- some markup or partial view -->
    }
    

    I would prefer this approach if either:

    1. The contained markup can be usefully contained in a partial such that it is reusable elsewhere.
    2. The conditional wrapping markup is more than a couple of lines, at which point escaping markup becomes messy.

    I should also add the option of using helper methods:

    @helper MainMarkup()
    {
        <!-- some markup or partial view -->
    }
    
    @if(isNew)
    {
        <div class="new">
            @MainMarkup()
        </div>
    }
    else
    {
        @MainMarkup()
    }
    

    This is useful if you want to use the second option above but avoid repeating markup or nesting too many partials (particularly if this markup is only relevant for this view).

    0 讨论(0)
提交回复
热议问题