MVC3 Razor ViewData

时间:2011-03-23 19:18:50

标签: asp.net-mvc-3 razor

我有一个在线表格。例如,它要求名字和姓氏。当他们提交时,我将他们发送到另一个视图。第二个视图还有一些文本框(密码,电子邮件地址,用户名),但它也有名字和姓氏。如果他们填写第一个表格并填写名字/姓氏,我希望第二个表格显示这些值,因为它们已被填写。

在第一种形式中,我将所有填写的信息放入TempData [“entry”]

在第二种形式中,我正在进行此项检查。

        if (TempData["entry"] != null)
        {
            var _model = (AccountInformationModel)TempData["entry"];

            ViewData["_firstName"] = _model.NameFirst;
            ViewData["_lastName"] = _model.NameLast;
        }

        return View("Register");

我想在我看来,我对如何在文本框中显示这些数据感到困惑。在我看来,我有这个,但它似乎没有起作用。

       <div class="editor-label">
            @Html.LabelFor(m => m.FirstName)
        </div>
        <div class="editor-field">
            @Html.TextBox("FirstName", ViewData["FirstName"])
            @Html.ValidationMessageFor(m => m.FirstName)
        </div>

显然是说......

   @Html.TextBox("FirstName", ViewData["FirstName"])

不起作用..

1 个答案:

答案 0 :(得分:9)

您将值分配给“_firstName”

ViewData["_firstName"] = _model.NameFirst;

然后尝试显示“FirstName”

@Html.TextBox("FirstName", ViewData["FirstName"])

尝试将其更改为:

@Html.TextBox("FirstName", ViewData["_firstName"])

另一种避免这种错误的方法是定义一个包含所有视图数据键的新类。这样,您的字符串就包含在一个位置,从而使维护和更改变得更容易。

public static class ViewDataKeys
{
    public const string FirstName = "_firstName";
}

然后,当您想要访问它时,您可以使用

ViewData[ViewDataKeys.FirstName] = _model.NameFirst;