跳到主要内容

Lifecycle Observers

在ChatGPT中打开

观察者允许组件对生命周期事件做出反应,通过为特定阶段实现接口。此模式确保关注点的清晰分离,并简化导航逻辑的处理。

可用的观察者

  • WillEnterObserver:允许您在进入路由之前处理任务,例如获取必要的数据或阻止导航。
  • DidEnterObserver:适用于在组件附加后处理动作,例如渲染数据或触发动画。
  • WillLeaveObserver:提供了一种在用户离开路由之前管理逻辑的方法,例如检查未保存的更改。
  • DidLeaveObserver:用于清理操作或其他应在组件从DOM中分离后运行的任务。

示例:使用 WillEnterObserver 进行身份验证

@Route(value = "dashboard")
public class DashboardView extends Composite<Div> implements WillEnterObserver {

@Override
public void onWillEnter(WillEnterEvent event, ParametersBag parameters) {
boolean isAuthenticated = authService.isAuthenticated();
event.veto(!isAuthenticated);

if (!isAuthenticated) {
event.getRouter().navigate(LoginView.class);
}
}
}

在这里,onWillEnter 检查用户是否经过身份验证。如果没有,则导航被否决,阻止导航的完成,并重定向到登录页面。

已验证路由示例 - 不适合生产环境

上述内容仅仅是如何使用已验证路由的示例。 这不是您编写生产级身份验证系统的示例。 您需要将所使用的概念和模式适应,以便与您的身份验证流程/系统一起使用。

示例:使用 DidEnterObserver 在路由条目时获取数据

@Route(value = "profile")
public class ProfileView extends Composite<Div> implements DidEnterObserver {

@Override
public void onDidEnter(DidEnterEvent event, ParametersBag parameters) {
String userId = parameters.get("userId").orElseThrow();
UserService.fetchProfile(userId).thenAccept(
profile -> updateProfileUI(profile));
}

private void updateProfileUI(Profile profile) {
// 更新UI以显示个人资料数据的代码
}
}

此示例演示了使用 DidEnterObserver 在组件附加到DOM后获取和显示个人资料数据。

示例:使用 WillLeaveObserver 处理未保存的更改

@Route(value = "edit-profile")
public class EditProfileView extends Composite<Div> implements WillLeaveObserver {
private boolean hasUnsavedChanges = false;

public EditProfileView() {
// 检测未保存更改的逻辑
}

@Override
public void onWillLeave(WillLeaveEvent event, ParametersBag parameters) {
event.veto(hasUnsavedChanges);

if(hasUnsavedChanges) {
ConfirmDialog.Result result = showConfirmDialog(
"存在未保存的更改。您想放弃还是保存它们?",
"未保存的更改",
ConfirmDialog.OptionType.OK_CANCEL,
ConfirmDialog.MessageType.WARNING);
}
}
}

在这个例子中,如果存在未保存的更改,onWillLeave 会提示用户确认对话框,若用户选择留下,则否决导航。

导航阻塞和否决处理

有关阻止导航的更多信息,请参见 导航阻塞和否决处理

示例:使用 DidLeaveObserver 清理

@Route(value = "notifications")
public class NotificationsView extends Composite<Div> implements DidLeaveObserver {

@Override
public void onDidLeave(DidLeaveEvent event, ParametersBag parameters) {
NotificationService.clearActiveNotifications();
}
}

此示例在用户离开 NotificationsView 后清除通知,使用 DidLeaveObserver 进行清理。