Razor에서 메소드를 어떻게 정의합니까?
답변
@functions 는 언제 ( 어쩌면 ) 언제해야하는지에 대한 논쟁을 떠나는 방법입니다.
@functions {
// Add code here.
}
답변
인라인 도우미를 의미합니까?
@helper SayHello(string name)
{
<div>Hello @name</div>
}
@SayHello("John")
답변
면도기 내부에 함수를 정의하는 것은 매우 간단합니다.
@functions {
public static HtmlString OrderedList(IEnumerable<string> items)
{ }
}
어디서나 함수를 호출 할 수 있습니다. 처럼
@Functions.OrderedList(new[] { "Blue", "Red", "Green" })
그러나 이와 동일한 작업을 수행 할 수도 있습니다 helper
. 예로서
@helper OrderedList(IEnumerable<string> items){
<ol>
@foreach(var item in items){
<li>@item</li>
}
</ol>
}
차이점은 무엇입니까 ?? 이 이전에 따르면 글 @helpers와 @functions는 공통점이 한 가지를 공유합니다. 웹 페이지 내에서 코드 재사용이 가능합니다. 그들은 또 다른 공통점을 공유합니다-언뜻보기에 동일하게 보이므로 역할에 약간의 혼란을 초래할 수 있습니다. 그러나 그것들은 동일하지 않습니다. 본질적으로 도우미는 메서드로 노출 된 재사용 가능한 Razor sytnax의 스 니펫이며 HTML을 브라우저에 렌더링하기위한 반면 함수는 웹 페이지 응용 프로그램 내 어디에서나 호출 할 수있는 정적 유틸리티 메서드입니다. 헬퍼의 리턴 유형은 항상 HelperResult 인 반면 함수의 리턴 유형은 원하는 유형입니다.
답변
이와 같은 Func으로도 할 수 있습니다.
@{
var getStyle = new Func<int, int, string>((width, margin) => string.Format("width: {0}px; margin: {1}px;", width, margin));
}
<div style="@getStyle(50, 2)"></div>
답변
답변
면도기 블록에서 로컬 함수 로 간단히 선언 할 수 있습니다 (예 🙂 @{}
.
@{
int Add(int x, int y)
{
return x + y;
}
}
<div class="container">
<p>
@Add(2, 5)
</p>
</div>
답변
또한 바로 사용할 수있는 @{ }
기능을 만들 블록 :
@{
async Task<string> MyAsyncString(string input)
{
return Task.FromResult(input);
}
}
그런 다음 나중에 면도기 페이지에서 :
<div>@(await MyAsyncString("weee").ConfigureAwait(false))</div>