다음을 통해 공유


요약 - 24장. 페이지 탐색

참고 항목

이 책은 2016년 봄에 출간되었으며, 그 후로 업데이트되지 않았습니다. 이 책의 많은 내용이 지금까지도 무척 유용하나, 일부 내용은 오래되었고 올바르지 않거나 완전하지 않은 주제도 있습니다.

많은 애플리케이션이 사용자가 탐색하는 여러 페이지로 구성됩니다. 애플리케이션은 항상 페이지 또는 페이지를 포함하고 있으며, 이 페이지에서 다른 페이지로 이동합니다. 이 페이지는 다시 탐색하기 위해 스택에서 유지됩니다. 추가 탐색 옵션은 25장에서 다룹니다. 페이지 종류.

VisualElementINavigation 형식의 Navigation 속성을 정의하며, 여기에는 새 페이지로 이동하는 다음 두 가지 메서드가 포함되어 있습니다.

두 메서드 모두 Page 인스턴스를 인수로 수락하고 Task 개체를 반환합니다. 다음 두 메서드는 이전 페이지로 돌아갑니다.

사용자 인터페이스에 자체 뒤로 단추가 있는 경우(예: Android 및 Windows Phone) 애플리케이션에서 이러한 메서드를 호출할 필요가 없습니다.

이러한 메서드는 모든 VisualElement에서 사용할 수 있지만 일반적으로 현재 Page 인스턴스의 Navigation 속성에서 호출됩니다.

애플리케이션은 일반적으로 사용자가 페이지에 대한 일부 정보를 제공해야 이전 페이지로 돌아갈 때 모달 페이지를 사용합니다. 모달이 아닌 페이지는 모덜리스 또는 계층적이라고도 합니다. 페이지 자체에서 모달 또는 모덜리스로 구분하는 것은 아닙니다. 이를 탐색하는 데 사용되는 메서드에 의해 제어됩니다. 모든 플랫폼에서 작업하려면 모달 페이지에서 이전 페이지로 돌아가기 위한 고유한 사용자 인터페이스를 제공해야 합니다.

ModelessAndModal 샘플을 사용하여 모덜리스 페이지와 모달 페이지의 차이를 살펴볼 수 있습니다. 페이지 탐색을 사용하는 모든 애플리케이션은 일반적으로 프로그램의 App 클래스에서 홈 페이지를 NavigationPage 생성자로 전달해야 합니다. 한 가지 보너스는 iOS 페이지에서 더 이상 Padding을 설정할 필요가 없다는 것입니다.

모덜리스 페이지의 경우 페이지의 Title 속성이 표시됩니다. iOS, Android 및 Windows 태블릿 및 데스크톱 플랫폼은 모두 이전 페이지로 돌아갈 수 있는 사용자 인터페이스 요소를 제공합니다. 물론, Android 및 Windows Phone 디바이스의 경우 뒤로 돌아가는 표준 뒤로 단추가 있습니다.

모달 페이지의 경우 페이지 Title이 표시되지 않으며 이전 페이지로 돌아가는 사용자 인터페이스 요소가 제공되지 않습니다. Android 및 Windows Phone 표준 뒤로 단추를 사용하여 이전 페이지로 돌아갈 수 있지만 다른 플랫폼의 모달 페이지는 돌아갈 수 있는 메커니즘을 제공해야 합니다.

페이지 전환 애니메이션

다양한 탐색 메서드의 대체 버전에서는 true로 설정하여 페이지 전환에 애니메이션을 포함할 수 있는 두 번째 부울 인수를 제공합니다.

그러나 표준 페이지 탐색 메서드는 기본적으로 애니메이션을 포함하므로 시작 시 특정 페이지로 이동하거나(이 챕터 끝부분에 설명된 대로) 또는 22장에서 설명한 대로 고유한 입구 애니메이션을 제공할 때만 유용합니다. 애니메이션).

시각적 개체 및 기능 변형

NavigationPage에는 App 메서드에서 클래스를 인스턴스화할 때 설정할 수 있는 두 가지 속성이 포함되어 있습니다.

또한 NavigationPage에는 설정된 특정 페이지에 영향을 주는 바인딩 가능한 속성 4개가 연결되어 있습니다.

메커니즘 탐색

페이지 탐색 메서드는 모두 비동기적이며 await와 함께 사용해야 합니다. 완료 시 페이지 탐색이 완료되었음을 나타내는 것이 아니므로 페이지 탐색 스택을 검사하는 것이 안전합니다.

한 페이지가 다른 페이지로 이동하면 첫 번째 페이지에는 일반적으로 OnDisappearing 메서드가 호출되고 두 번째 페이지에는 OnAppearing 메서드가 호출됩니다. 마찬가지로 한 페이지가 다른 페이지로 돌아갈 때 첫 번째 페이지에는 OnDisappearing 메서드가 호출되고 두 번째 페이지에는 일반적으로 해당 OnAppearing 메서드가 호출됩니다. 이러한 호출(및 탐색을 호출하는 비동기 메서드의 완료) 순서는 플랫폼에 따라 다릅니다. 앞의 두 문장에서 "일반적으로"라는 단어를 사용한 것은 이러한 메서드 호출이 발생하지 않는 Android 모달 페이지 탐색 때문입니다.

또한 OnAppearingOnDisappearing 메서드 호출이 반드시 페이지 탐색을 나타내는 것은 아닙니다.

INavigation 인터페이스에는 탐색 스택을 검사하는 데 사용할 수 있는 두 가지 컬렉션 속성이 포함되어 있습니다.

  • 모덜리스 스택에 대한 IReadOnlyList<Page> 형식의 NavigationStack
  • 모달 스택에 대한 IReadOnlyList<Page> 형식의 ModalStack

NavigationPageNavigation 속성(App 클래스의 MainPage 속성)에서 이러한 스택에 액세스하는 것이 가장 안전합니다. 비동기 페이지 탐색 메서드가 완료된 후에만 이러한 스택을 검사해도 됩니다. 현재 페이지가 모달 페이지인 경우에는 NavigationPageCurrentPage 속성은 현재 페이지를 나타내지 않고 대신 마지막 모덜리스 페이지를 나타냅니다.

SinglePageNavigation 샘플을 사용하면 페이지 탐색 및 스택과 올바른 유형의 페이지 탐색을 살펴볼 수 있습니다.

  • 모덜리스 페이지는 다른 모덜리스 페이지 또는 모달 페이지로 이동할 수 있습니다.
  • 모달 페이지는 다른 모달 페이지로만 이동할 수 있습니다.

모달 적용

애플리케이션은 사용자로부터 일부 정보를 가져와야 하는 경우 모달 페이지를 사용합니다. 사용자는 해당 정보를 제공할 때까지 이전 페이지로 돌아갈 수 없습니다. iOS에서는 뒤로 단추를 제공하고 사용자가 페이지를 완료한 경우에만 이 단추를 사용하도록 설정하는 것이 쉽습니다. 하지만 Android 및 Windows Phone 디바이스의 경우 ModalEnforcement 샘플에서 설명한 대로 애플리케이션은 OnBackButtonPressed 메서드를 재정의하고 프로그램이 뒤로 단추 자체를 처리한 경우 true을 반환해야 합니다.

MvvmEnforcement 샘플에서는 MVVM 시나리오에서 이 프로세스가 어떻게 작동하는지 보여 줍니다.

특정 모달 페이지로 여러 번 이동할 수 있는 경우에는 사용자가 다시 모든 정보를 입력하는 대신 정보를 편집할 수 있도록 정보를 유지해야 합니다. 모달 페이지의 특정 인스턴스를 유지하여 이를 처리할 수 있지만, 특히 iOS의 경우에는 보기 모델의 정보를 유지하는 것이 좋습니다.

탐색 메뉴 만들기

ViewGalleryType 샘플에서는 TableView를 사용하여 메뉴 항목을 나열하는 방법을 보여 줍니다. 각 항목은 특정 페이지에 대한 Type 개체와 연결됩니다. 해당 항목이 선택되면 프로그램에서 페이지를 인스턴스화하고 이동합니다.

보기 갤러리 형식의 삼중 스크린샷

ViewGalleryInst 샘플은 메뉴에 형식 대신 각 페이지의 인스턴스가 포함된다는 점에서 약간 차이가 있습니다. 이렇게 하면 각 페이지의 정보를 유지하는 데 도움이 되지만 프로그램을 시작할 때 모든 페이지를 인스턴스화해야 합니다.

탐색 스택 조작

StackManipulation은 구조화된 방식으로 탐색 스택을 조작할 수 있는, INavigation에 정의된 여러 함수를 보여 줍니다.

동적 페이지 생성

BuildAPage 샘플에서는 사용자 입력을 기반으로 런타임에 페이지를 생성하는 방법을 보여 줍니다.

데이터 전송 패턴

탐색된 페이지로 데이터를 전송하고 페이지를 호출한 페이지로 데이터를 반환하려면 페이지 간에 데이터를 공유해야 하는 경우가 많습니다. 이 작업을 수행하는 방법에는 여러 가지가 있습니다.

생성자 인수

새 페이지로 이동할 때 페이지를 자체적으로 초기화할 수 있도록 하는 생성자 인수를 사용하여 페이지 클래스를 인스턴스화할 수 있습니다. SchoolAndStudents 샘플에서는 이를 보여 줍니다. 탐색한 페이지가 탐색된 페이지에서 해당 BindingContext를 설정하는 것도 가능합니다.

속성 및 메서드 호출

나머지 데이터 전송 예제에서는 한 페이지가 다른 페이지로 이동했다가 되돌아갈 때 페이지 간에 정보를 전달하는 문제를 살펴봅니다. 이러한 설명에서 페이지는 정보 페이지로 이동하고 초기화된 정보를 정보 페이지로 전송해야 합니다. 정보 페이지는 사용자로부터 추가 정보를 가져오고 이 정보를 페이지로 전송합니다.

페이지는 해당 페이지를 인스턴스화하는 즉시 정보 페이지에서 공용 메서드 및 속성에 쉽게 액세스할 수 있습니다. 정보 페이지도 페이지에서 공용 메서드 및 속성에 액세스할 수도 있지만 이를 위해 적절한 타이밍을 선택하는 것은 어려울 수 있습니다. DateTransfer1 샘플에서는 이를 OnDisappearing 재정의에서 수행합니다. 한 가지 단점은 정보 페이지가 페이지의 유형을 알고 있어야 한다는 것입니다.

MessagingCenter

클래스는 Xamarin.FormsMessagingCenter 두 페이지가 서로 통신하는 또 다른 방법을 제공합니다. 메시지는 텍스트 문자열로 식별되며 모든 개체를 함께 사용할 수 있습니다.

특정 형식의 메시지를 수신하려는 프로그램은 MessagingCenter.Subscribe를 사용하여 구독해야 하며 콜백 함수를 지정해야 합니다. 나중에 MessagingCenter.Unsubscribe를 호출하여 구독을 취소할 수 있습니다. 콜백 함수는 Send 메서드를 통해 전송된 지정된 이름을 사용하여 지정된 형식에서 전송된 모든 메시지를 받습니다.

DateTransfer2 프로그램은 메시징 센터를 사용하여 데이터를 전송하는 방법을 보여 주지만, 이를 위해 정보 페이지가 페이지의 유형을 알아야 합니다.

이벤트

이벤트는 클래스의 형식을 몰라도 한 클래스에서 다른 클래스로 정보를 보낼 수 있는 오래된 방법입니다. DateTransfer3 샘플에서 info 클래스는 정보가 준비되었을 때 발생하는 이벤트를 정의합니다. 그러나 페이지에서 이벤트 처리기를 분리하기에 편리한 장소가 없습니다.

App 클래스 중개자

DateTransfer4 샘플에서는 App 클래스에서 페이지 및 정보 페이지 모두에 의해 정의된 속성에 액세스하는 방법을 보여 줍니다. 이것도 좋은 솔루션이지만 다음 섹션에서 더 나은 솔루션을 설명합니다.

ViewModel로 전환

정보에 ViewModel을 사용하면 페이지와 정보 페이지가 정보 클래스의 인스턴스를 공유할 수 있습니다. 이는 DateTransfer5 샘플에서 설명합니다.

페이지 상태 저장 및 복원

App 클래스 중개자 또는 ViewModel 접근 방식은 정보 페이지가 활성화되어 있는 동안 프로그램이 절전 모드로 전환되는 경우 애플리케이션에서 정보를 저장해야 하는 경우에 매우 적합합니다. DateTransfer6 샘플에서는 이를 보여 줍니다.

탐색 스택 저장 및 복원

일반적으로 절전 모드로 전환되는 다중 페이지 프로그램은 복원될 때 동일한 페이지로 이동해야 합니다. 즉, 이러한 프로그램은 탐색 스택의 내용을 저장해야 합니다. 이 섹션에서는 이 용도로 설계된 클래스에서 이 프로세스를 자동화하는 방법을 보여 줍니다. 또한 이 클래스는 개별 페이지를 호출하여 해당 페이지 상태를 저장하고 복원할 수 있도록 합니다.

Xamarin.FormsBook.Toolkit 라이브러리는 클래스가 Properties 사전에 항목을 저장하고 복원하기 위해 구현할 수 있는 IPersistantPage라는 인터페이스를 정의합니다.

Xamarin.FormsBook.Toolkit 라이브러리의 MultiPageRestorableApp 클래스는 Application에서 파생됩니다. 그런 다음 MultiPageRestorableApp에서 App 클래스를 파생시키고 약간의 정리를 수행할 수 있습니다.

StackRestoreDemo에서는 MultiPageRestorableApp를 사용하는 방법을 보여 줍니다.

실제 앱과 같은 항목

또한 NoteTaker 샘플에서는 MultiPageRestorableApp을 사용하고 Properties 사전에 메모를 입력하고 저장된 메모를 편집할 수 있습니다.