共用方式為


NavigationService.Navigating 事件

定義

要求新的巡覽時發生。

public:
 event System::Windows::Navigation::NavigatingCancelEventHandler ^ Navigating;
public event System.Windows.Navigation.NavigatingCancelEventHandler Navigating;
member this.Navigating : System.Windows.Navigation.NavigatingCancelEventHandler 
Public Custom Event Navigating As NavigatingCancelEventHandler 

事件類型

範例

下列範例示範如何處理 Navigating 以偵測是否已提出重新整理靜態內容的要求,如果是的話,則取消要求。

Navigating.

void NavigationService_Navigating(object sender, NavigatingCancelEventArgs e)
{
    // Don't allow refreshing of a static page
    if ((e.NavigationMode == NavigationMode.Refresh) &&
        (e.Uri.OriginalString == "StaticPage.xaml"))
    {
        e.Cancel = true;
    }
}
Private Sub NavigationService_Navigating(ByVal sender As Object, ByVal e As NavigatingCancelEventArgs)
    ' Don't allow refreshing of a static page
    If (e.NavigationMode = NavigationMode.Refresh) AndAlso (e.Uri.OriginalString = "StaticPage.xaml") Then
        e.Cancel = True
    End If
End Sub

備註

Navigating 會在要求新的流覽時引發,但在要求來源內容之前,包括何時:

如果您需要在流覽開始之前探索流覽要求的相關資訊,請處理 Navigating 。 這項資訊可從 NavigatingCancelEventArgs 傳遞至 Navigating 事件處理常式的物件取得。

WebRequest導覽的 物件是從 參數建立且可供使用 NavigatingCancelEventArgs ;因為目前尚未提出實際要求,因此您可以視需要重新設定 WebRequest 物件。

NavigatingCancelEventArgs您也可以視需要將 設定 Cancel 為 true 來處理取消流覽。 如果您取消流覽,則不會引發任何其他導覽事件。

注意

如果您的應用程式裝載于瀏覽器中,則您無法取消 Navigating 事件來防止使用者離開您的應用程式。

導覽器 (NavigationWindow 巡覽至第一個內容片段之後, Frame) ,則會將流覽離開的每個內容片段新增至流覽歷程記錄。 如果您需要儲存您要離開之內容的狀態資訊,您可以設定 ContentStateToSaveCustomContentState 物件,將狀態新增至該內容的記錄項目。

注意

當 引發 NavigatingNavigationService ,也會在 物件上 Application 引發 Application.Navigating 事件。

適用於

另請參閱