Razor에서 메소드를 어떻게 정의합니까?
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>
면도기는 단지 템플릿 엔진입니다.
정규 수업을 만들어야합니다.
Razor 페이지 내부에서 메소드를 작성하려면 @functions
블록에 넣습니다 .
또한 바로 사용할 수있는 @{ }
기능을 만들 블록 :
@{
async Task<string> MyAsyncString(string input)
{
return Task.FromResult(input);
}
}
그런 다음 나중에 면도기 페이지에서
<div>@(await MyAsyncString("weee").ConfigureAwait(false))</div>
면도기 블록에서 로컬 함수 로 간단히 선언 할 수 있습니다 (예 :) @{}
.
@{
int Add(int x, int y)
{
return x + y;
}
}
<div class="container">
<p>
@Add(2, 5)
</p>
</div>
참고 URL : https://stackoverflow.com/questions/5159877/how-do-i-define-a-method-in-razor
'IT story' 카테고리의 다른 글
IE에서 event.preventDefault () 함수가 작동하지 않습니다 (0) | 2020.05.08 |
---|---|
비어있을 때 HTML 텍스트 상자에 힌트를 표시하려면 어떻게해야합니까? (0) | 2020.05.08 |
android.widget.Switch-이벤트 리스너를 켜거나 끕니다? (0) | 2020.05.08 |
배열 요소를 제거한 다음 배열을 다시 색인하는 방법? (0) | 2020.05.08 |
Rails 4에서 CSS로 이미지를 참조하는 방법 (0) | 2020.05.08 |