Tôi đã kết thúc với một phương pháp mở rộng tùy chỉnh. Đáng chú ý của nó, khi cố gắng đặt HTML bên trong một đối tượng Anchor, văn bản liên kết có thể ở bên trái hoặc bên phải của HTML bên trong. Vì lý do này, tôi đã chọn cung cấp các tham số cho HTML bên trong bên trái và bên phải - văn bản liên kết nằm ở giữa. Cả HTML bên trái và bên phải là tùy chọn.
Phương pháp mở rộng ActionLinkInnerHtml:
public static MvcHtmlString ActionLinkInnerHtml(this HtmlHelper helper, string linkText, string actionName, string controllerName, RouteValueDictionary routeValues = null, IDictionary<string, object> htmlAttributes = null, string leftInnerHtml = null, string rightInnerHtml = null)
{
// CONSTRUCT THE URL
var urlHelper = new UrlHelper(helper.ViewContext.RequestContext);
var url = urlHelper.Action(actionName: actionName, controllerName: controllerName, routeValues: routeValues);
// CREATE AN ANCHOR TAG BUILDER
var builder = new TagBuilder("a");
builder.InnerHtml = string.Format("{0}{1}{2}", leftInnerHtml, linkText, rightInnerHtml);
builder.MergeAttribute(key: "href", value: url);
// ADD HTML ATTRIBUTES
builder.MergeAttributes(htmlAttributes, replaceExisting: true);
// BUILD THE STRING AND RETURN IT
var mvcHtmlString = MvcHtmlString.Create(builder.ToString());
return mvcHtmlString;
}
Ví dụ về cách sử dụng:
Dưới đây là một ví dụ về việc sử dụng. Trong ví dụ này, tôi chỉ muốn html bên trong ở bên phải của văn bản liên kết ...
@Html.ActionLinkInnerHtml(
linkText: "Hello World"
, actionName: "SomethingOtherThanIndex"
, controllerName: "SomethingOtherThanHome"
, rightInnerHtml: "<span class=\"caret\" />"
)
Các kết quả:
kết quả này trong HTML sau ...
<a href="/SomethingOtherThanHome/SomethingOtherThanIndex">Hello World<span class="caret" /></a>