89

WORKS

<a href="@Url.Action("edit", "markets", new { id = 1 })" 
            data-rel="dialog" data-transition="pop" data-icon="gear" class="ui-btn-right">Edit</a>

動作しません-なぜですか?

@Html.ActionLink("Edit", "edit", "markets", new { id = 1 }, new {@class="ui-btn-right", data-icon="gear"})

data-icon = "gear"のようなものをhtmlAttributesに渡すことができないようですか?

提案?

4

3 に答える 3

207

問題は、匿名オブジェクト プロパティdata-iconの名前が無効であることです。C# プロパティの名前にダッシュを含めることはできません。これを回避するには、次の 2 つの方法があります。

ダッシュの代わりにアンダースコアを使用します (MVC は、出力された HTML でアンダースコアを自動的にダッシュに置き換えます)。

@Html.ActionLink("Edit", "edit", "markets",
      new { id = 1 },
      new {@class="ui-btn-right", data_icon="gear"})

辞書を受け取るオーバーロードを使用します。

@Html.ActionLink("Edit", "edit", "markets",
      new { id = 1 },
      new Dictionary<string, object> { { "class", "ui-btn-right" }, { "data-icon", "gear" } });
于 2010-11-05T22:35:14.703 に答える
26

目的のハイフンをアンダースコアに置き換えます。自動的にハイフンとしてレンダリングされます:

@Html.ActionLink("Edit", "edit", "markets",
    new { id = 1 },
    new {@class="ui-btn-right", data_icon="gear"})

になります:

<form action="markets/Edit/1" class="ui-btn-right" data-icon="gear" .../>
于 2011-12-22T06:50:52.393 に答える
-6
@Html.ActionLink("display name", "action", "Contorller"
    new { id = 1 },Html Attribute=new {Attribute1="value"})
于 2016-08-18T07:12:53.517 に答える