如何在Razor中声明一个局部变量

本文关键字:一个 局部变量 声明 Razor | 更新日期: 2023-09-27 18:01:17

我正在asp.net mvc 3中开发一个web应用程序。我对它很陌生。在使用razor的视图中,我想声明一些局部变量,并在整个页面中使用它。如何做到这一点?

能够执行以下操作似乎相当微不足道:

@bool isUserConnected = string.IsNullOrEmpty(Model.CreatorFullName);
@if (isUserConnected)
{ // meaning that the viewing user has not been saved
    <div>
        <div> click to join us </div>
        <a id="login" href="javascript:void(0);" style="display: inline; ">join</a>
    </div>
}

但这不起作用。这可能吗?

如何在Razor中声明一个局部变量

我想你已经很接近了,试试这个:

@{bool isUserConnected = string.IsNullOrEmpty(Model.CreatorFullName);}
@if (isUserConnected)
{ // meaning that the viewing user has not been saved so continue
    <div>
        <div> click to join us </div>
        <a id="login" href="javascript:void(0);" style="display: inline; ">join here</a>
    </div>
}

我认为变量应该在同一块中:

@{
    bool isUserConnected = string.IsNullOrEmpty(Model.CreatorFullName);
    if (isUserConnected)
    { 
        // meaning that the viewing user has not been saved
        <div>
            <div> click to join us </div>
            <a id="login" href="javascript:void(0);" style="display: inline; ">join</a>
        </div>
    }
}

您也可以使用:

@if(string.IsNullOrEmpty(Model.CreatorFullName))
{
...your code...
}

代码中不需要变量

不是对OP问题的直接回答,但它也可能对您有所帮助。你可以在作用域内的html旁边声明一个局部变量。

@foreach (var item in Model.Stuff)
{
    var file = item.MoreStuff.FirstOrDefault();
    <li><a href="@item.Source">@file.Name</a></li>
}

如果您正在寻找一个int型变量,一个随着代码循环而增加的变量,您可以使用这样的东西:

@{
  int counter = 1;
  foreach (var item in Model.Stuff) {
    ... some code ...
    counter = counter + 1;
  }
} 

如果您希望在整个页面中都可以访问一个变量,那么在文件的顶部定义它会很好。(可以使用隐式或显式类型)

@{
    // implicit type
    var something1 = "something";
    // explicit type
    string something2 = "something";
}
<div>@something1</div> @*display first variable*@
<div>@something2</div> @*display second variable*@

你可以把所有东西放在一个块里,然后很容易地在这个块里写任何你想写的代码,就像下面的代码:

@{
        bool isUserConnected = string.IsNullOrEmpty(Model.CreatorFullName);
        if (isUserConnected)
        { // meaning that the viewing user has not been saved
            <div>
                <div> click to join us </div>
                <a id="login" href="javascript:void(0);" style="display: inline; ">join</a>
            </div>
        }
    }

它可以帮助你首先有一个更干净的代码,也可以防止你的页面加载多次不同的代码块