I have the following table located in a view within a controller named Student (/Student/Details/1):
@foreach (var item in Model.Enrollments)
{
<tr>
<td>
@Html.DisplayFor(modelItem => item.Course.Title)
</td>
<td>
@Html.DisplayFor(modelItem => item.Grade)
</td>
</tr>
}
I would like to make each table definition into a link that takes me to a view within a controller named Course (/Course/Details/1).
I have tried things along the lines of:
@Html.ActionLink(Html.DisplayFor(modelItem => item.Course.Title, "Details", "Course"))
in place of
@Html.DisplayFor(modelItem => item.Course.Title)
Which does not compile. How would I appropriately display my model's title along with a link to the details of the referenced title?
If I understand right your question, you want a link with the text of the course.
This should work:
@Html.ActionLink(item.Course.Title, "Details", "Course")
If you want to pass the ID of the course to the controller (assuming your routing rules are set correctly and the Id is something like: item.Course.Id)
@Html.ActionLink(item.Course.Title, "Details", "Course", new { Id = item.Course.Id }, null /* html attributes */)
If you need to use the UIHint attribute on the property, to add extra formatting, you can use this
<a href="@Url.Action("Details", "Course", new { Id=item.Course.Id})">@Html.DisplayFor(modelItem => item.Course.Title)</a>