> 백엔드 개발 > C++ > API 호출 후 하위 구성 요소에서 기본 .RAZOR 페이지를 새로 고치는 방법은 무엇입니까?

API 호출 후 하위 구성 요소에서 기본 .RAZOR 페이지를 새로 고치는 방법은 무엇입니까?

Susan Sarandon
풀어 주다: 2025-01-09 19:42:41
원래의
193명이 탐색했습니다.

How to Refresh a Main .RAZOR Page from Child Components After an API Call?

API 호출이 완료된 후 하위 구성 요소에서 기본 .RAZOR 페이지를 트리거/새로 고치는 방법

문제 개요

API 호출이 완료되고 데이터를 사용할 수 있게 되면 기본 .RAZOR 페이지를 새로 고쳐야 합니다. 문제는 데이터가 준비되었음을 나타내고 이에 따라 페이지 새로 고침을 시작하는 "트리거"를 찾는 것입니다.

솔루션

1. 범위 서비스(AppState) 구현

반환된 데이터 세트를 관리하고 애플리케이션의 모든 구성 요소에 액세스할 수 있도록 범위가 지정된 서비스(AppState)를 만듭니다.

2. 표시 구성 요소(SearchResults.razor)

SearchResults.razor에서 페이지가 로드될 때 AppState 서비스에서 데이터를 가져와 루프에 표시합니다. API가 데이터를 반환할 때 if 문을 사용하여 조건부로 데이터를 표시하거나 스피너를 로드합니다.

3. 서브 필터 구성품 통합

사용자가 하위 구성 요소에서 필터를 적용하는 경우 각 구성 요소에 다음 코드를 사용하세요.

<code class="language-csharp">string href = "/searchresults" + // 其他参数在此处 ...
NavigationManager.NavigateTo(href);</code>
로그인 후 복사

필터가 적용될 때 항상 SearchResults.razor로 리디렉션됩니다.

4. 상태/알림 모드 활용

AppState 서비스에서 변경 사항을 브로드캐스트하는 상태/알림 패턴을 구현합니다. 이는 하위 구성 요소에서 다음 방법을 사용하여 달성할 수 있습니다.

<code class="language-csharp">// FilterRazorComponent01.razor 中的示例
//...

public async Task OnSomeEventAsync()
{
    // 模拟一些 API 调用并触发数据更新
    await Task.Delay(3000);
    AppState.NotifyListChanged(AppState.Records, EventArgs.Empty);
    NavigationManager.NavigateTo(NavigationManager.Uri);
}</code>
로그인 후 복사

5. 알림 이벤트 등록

SearchResults.razor에서 AppState의 ListChanged 이벤트를 등록하고 이벤트가 실행될 때 StateHasChanged를 호출하여 새로 고침을 트리거합니다.

<code class="language-csharp">this.AppState.ListChanged += this.OnListChanged;
//...

private void OnListChanged(object sender, EventArgs e)
    => this.InvokeAsync(this.StateHasChanged);</code>
로그인 후 복사

6. 하위 이벤트 페이지 새로고침 처리

하위 구성 요소가 AppState를 업데이트하는 이벤트를 트리거하면 ListChanged 이벤트가 브로드캐스트되고 SearchResults.razor는 페이지를 새로 고치기 위해 StateHasChanged를 트리거하여 응답합니다. 이렇게 하면 필터 구성 요소의 변경 사항에 따라 기본 페이지의 표시가 업데이트됩니다.

위 내용은 API 호출 후 하위 구성 요소에서 기본 .RAZOR 페이지를 새로 고치는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿