19

私は検索しましたが、MVC 3 htmlhelper がラッパー メソッドを作成するための簡単な解決策を見つけることができませんでした。私が探しているのは次のようなものです:

@html.createLink("caption", "url")
{
    <html> content in tags </html>
}

結果は

<a href="url" title="Caption">
  <html> content in tags </html>
</a>

これについて何か助けてください。

4

3 に答える 3

46

これを BeginForm で行う方法は、ステートメント内で使用されるとメソッドが終了タグを書き出すように戻り値の型を実装MvcFormすることです。IDisposableusingDisposeMvcForm</form>

まったく同じことを行う拡張メソッドを作成できます。

ここに私がデモンストレーションのために書いたものがあります。

まず、拡張メソッド:

public static class ExtensionTest
{
    public static MvcAnchor BeginLink(this HtmlHelper htmlHelper)
    {
        var tagBuilder = new TagBuilder("a");
        htmlHelper.ViewContext.Writer
                        .Write(tagBuilder.ToString(
                                             TagRenderMode.StartTag));
        return new MvcAnchor(htmlHelper.ViewContext);
    }
}

そして、これが新しい型 MvcAnchor です。

public class MvcAnchor : IDisposable
{
    private readonly TextWriter _writer;
    public MvcAnchor(ViewContext viewContext)
    {
        _writer = viewContext.Writer;
    }

    public void Dispose()
    {
        this._writer.Write("</a>");
    }
}

ビューで次のことができるようになりました。

@{
    using (Html.BeginLink())
    { 
        @Html.Raw("Hello World")
    }
}

結果は次のとおりです。

<a>Hello World</a>

これを少し拡張して、正確な要件に対処します。

public static MvcAnchor BeginLink(this HtmlHelper htmlHelper, 
                                   string href, 
                                   string title)
{
    var tagBuilder = new TagBuilder("a");
    tagBuilder.Attributes.Add("href",href);
    tagBuilder.Attributes.Add("title", title);
    htmlHelper.ViewContext.Writer.Write(tagBuilder
                                    .ToString(TagRenderMode.StartTag));
    return new MvcAnchor(htmlHelper.ViewContext);
}

そして私たちの見解:

@{
  using (Html.BeginLink("http://stackoverflow.com", "The Worlds Best Q&A site"))
  { 
      @Html.Raw("StackOverflow - Because we really do care")
  }
}

結果は次のようになります。

<a href="http://stackoverflow.com" title="The Worlds Best Q&amp;A site">
   StackOverflow - Because we really do care</a>
于 2012-05-17T14:33:28.380 に答える
9

使い捨てのトリックなしで、別の方法もあります。作業が少なくて済み、小さなヘルパーに最適です。私は同様の質問に答えました、そしてすべてをコピーしたくありません、しかしここに短い例があります:

@helper Paragraph(string cssClass, Func<object, object> markup) {
    <p class="@cssClass">@markup.DynamicInvoke(this.ViewContext)</p>
}

このヘルパーの使用法は次のようになります。

@Paragraph("highlited", 
    @<text>
        Look, a @Html.ActionLink("link", "index")
    </text>
)

ここにある他の同様の質問に対する私の完全な答え。

于 2012-12-10T13:43:38.310 に答える
2

最も単純なレベルでは、このようなものがそれを行います

public static MvcHtmlString SomeLink(this HtmlHelper htmlHelper, string href, string     title,  string content )
    {
        var urlHelper = ((Controller)htmlHelper.ViewContext.Controller).Url;
        //var url = urlHelper.Action(actionName, controllerName, routeValues);

        var someLink = new TagBuilder("a");
        someLink.MergeAttribute("href", href);
        someLink.InnerHtml = content;

        return new MvcHtmlString(someLink.ToString());
    }
于 2012-05-17T11:59:52.707 に答える