HTML.ActionLink
和Url.Action
是否有区别,还是它们只是完成同一件事的两种不同方式?
在什么情况下应该优先选择其中一种?
HTML.ActionLink
和Url.Action
是否有区别,还是它们只是完成同一件事的两种不同方式?
在什么情况下应该优先选择其中一种?
是的,有区别。 Html.ActionLink
生成一个 <a href=".."></a>
标签,而 Url.Action
只返回一个网址。
例如:
@Html.ActionLink("link text", "someaction", "somecontroller", new { id = "123" }, null)
生成:
<a href="/somecontroller/someaction/123">link text</a>
Url.Action("someaction", "somecontroller", new { id = "123" })
会生成:
/somecontroller/someaction/123
还有一个Html.Action,可以执行子控制器操作。
Html.ActionLink
会自动生成一个<a href=".."></a>
标签。
Url.Action
仅生成一个URL链接。
例如:
@Html.ActionLink("link text", "actionName", "controllerName", new { id = "<id>" }, null)
<a href="/controllerName/actionName/<id>">link text</a>
@Url.Action("actionName", "controllerName", new { id = "<id>" })
生成:
/controllerName/actionName/<id>
我最喜欢的优点是使用Url.Action(...)
你可以自己创建锚标签,甚至可以使用其他 HTML 标记轻松设置自己的链接文本。
<a href="@Url.Action("actionName", "controllerName", new { id = "<id>" })">
<img src="<ImageUrl>" style"width:<somewidth>;height:<someheight> />
@Html.DisplayFor(model => model.<SomeModelField>)
</a>
@HTML.ActionLink
生成一个 HTML 锚点标签
,而 @Url.Action
为你生成一个 URL
。你可以通过以下方式轻松理解它:
// 1. <a href="/ControllerName/ActionMethod">Item Definition</a>
@HTML.ActionLink("Item Definition", "ActionMethod", "ControllerName")
// 2. /ControllerName/ActionMethod
@Url.Action("ActionMethod", "ControllerName")
// 3. <a href="/ControllerName/ActionMethod">Item Definition</a>
<a href="@Url.Action("ActionMethod", "ControllerName")"> Item Definition</a>
这两种方法都不同,完全取决于您的需求。
<p>
@Html.ActionLink("Create New", "Create")
</p>
@using (Html.BeginForm("Index", "Company", FormMethod.Get))
{
<p>
Find by Name: @Html.TextBox("SearchString", ViewBag.CurrentFilter as string)
<input type="submit" value="Search" />
<input type="button" value="Clear" onclick="location.href='@Url.Action("Index","Company")'"/>
</p>
}
在上面的例子中,你可以看到如果我需要一个按钮执行某个操作,我必须使用@Url.Action,而如果我只想要一个链接,我会使用@Html.ActionLink。
重点是当你需要使用带有动作URL的某些元素(HTML)时使用它。您可以使用适当的CSS样式将Html.ActionLink轻松呈现为按钮。例如:
@Html.ActionLink("Save", "ActionMethod", "Controller", new { @class = "btn btn-primary" })
<input type="button" value="PDF" onclick="location.href='@Url.Action("Export","tblOrder")'"/>
Html.ActionLink
来生成它们。不要试图进行微小的优化,否则您的视图代码将变得丑陋。 - Darin Dimitrov<a>
)时,请使用Html.ActionLink。在只需要生成URL时(这也可以在控制器操作中使用),请使用Url.Action。 - Darin DimitrovUrl.Action
比Html.ActionLink
性能更好。我有一个列表包含6,000个项目,其中每个项目都有2个Html.ActionLinks
。渲染该列表需要6,600ms的时间。如果去掉Html.ActionLinks
,只需要52ms的时间。使用Url.Action
花费了270ms的时间。当然,6,000个项目是一个很大的列表,但是我认为这可以作为以后参考的依据。 - Rob Sutherland