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?
Yes, there is a difference. Html. ActionLink generates an <a href=".."></a> tag whereas Url. Action returns only an url.
Html. ActionLink creates a hyperlink on a view page and the user clicks it to navigate to a new URL. It does not link to a view directly, rather it links to a controller's action.
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>
You forgot an )
after Html.DisplayFor(modelItem => item.Course.Title
.
Maybe try adding a .ToString()
to it might help.
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With