我有一个在线表格。例如,它要求名字和姓氏。当他们提交时,我将他们发送到另一个视图。第二个视图还有一些文本框(密码,电子邮件地址,用户名),但它也有名字和姓氏。如果他们填写第一个表格并填写名字/姓氏,我希望第二个表格显示这些值,因为它们已被填写。
在第一种形式中,我将所有填写的信息放入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"])
不起作用..
答案 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;