ActionLink htmlAttributes


88

공장

<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에 전달할 수없는 것 같습니다.

제안?

답변:


204

문제는 익명 개체 속성 data-icon에 잘못된 이름 이 있다는 것 입니다. C # 속성은 이름에 대시를 사용할 수 없습니다. 이를 해결할 수있는 두 가지 방법이 있습니다.

대시 대신 밑줄을 사용합니다 (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" } });

2
밑줄로 작동하지 않는 것 Ajax.ActionLink헬퍼
드미트리 에피 멘코에게

1
밑줄 트릭은 정말 이상하게 들립니다. html 속성에 밑줄을 넣으려면 어떻게해야합니까?
Michiel

1
@MichielReyers 당신은 사전에 걸리는 과부하를 사용할 수 있습니다
marcind

1
.net Core Tag Helpers는 이러한 모든 문제를 파괴합니다. 안녕하세요.
niico

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" .../>

당사 사이트를 사용함과 동시에 당사의 쿠키 정책개인정보 보호정책을 읽고 이해하였음을 인정하는 것으로 간주합니다.
Licensed under cc by-sa 3.0 with attribution required.