此代码无法工作,因为您的LINQ查询正在返回一个匿名对象,因此您无法强烈键入您的视图。所以第一步是定义,这将代表你愿意显示在您的视图中的信息视图模型:
public class UserViewModel
{
public string UserName { get; set; }
public DateTime LastActivityDate { get; set; }
public string Address { get; set; }
public string City { get; set; }
public string State { get; set; }
public string Zip { get; set; }
}
然后在你的控制器动作,您将回到这个视图模型的集合:
在强类型视图
public ActionResult Index()
{
var currentUser = Membership.GetUser();
var userId = (Guid)currentUser.ProviderUserKey;
var users =
from m in db.Users
join m2 in db.MyProfiles on m.UserId equals m2.UserId
where m.UserId == userId
select new UserViewModel
{
UserName = m.UserName,
LastActivityDate = m.LastActivityDate,
Address = m2.Address,
City = m2.City,
State = m2.State,
Zip = m2.Zip
};
return View(users);
}
最后:
@model IEnumerable<AppName.Models.UserViewModel>
@Html.DisplayForModel()
,并在其中将呈现为相应的显示模板(~/Views/Shared/DisplayTemplates/UserViewModel.cshtml
)收集的每个项目:
@model AppName.Models.UserViewModel
<div>
Username: @Html.DisplayFor(x => x.UserName)<br/>
Last activity: @Html.DisplayFor(x => x.LastActivityDate)<br/>
...
</div>