从前端路由到 Android ARouter:观察者模式在不同平台的同一种落地

一、先给读者一个"统一结论"(很重要)

你可以在这一节一开头就点破:

不论是前端路由、Android 的 ARouter,还是 Flutter 的 go_router,

它们表面 API 完全不同,但底层解决的是同一件事
当"导航状态"发生变化时,系统自动完成页面切换。

这背后,本质都是观察者模式

二、前端路由(Vue / React Router)在干什么?

1️⃣ 前端路由的核心事实

在前端世界里,有一个天然的"被观察者"

URL

  • URL 变化

  • 页面自动变化

  • 开发者不需要手动"销毁/创建页面"

2️⃣ 一个典型前端路由表示例

javascript 复制代码
const routes = [
  { path: '/login', component: Login },
  { path: '/order/:id', component: Order }
]

当 URL 从:

/login → /order/123

发生变化时:

  • 路由系统监听到 URL 变化
  • 匹配路由表
  • 渲染新的组件

3️⃣ 用观察者模式语言解释

角色 对应
Subject URL / history
Observer Router
notify URL change
update 重新渲染组件

前端路由 = 浏览器 URL 变化 → 路由系统自动响应

三、前端的 beforeEach 是什么角色?

javascript 复制代码
router.beforeEach((to, from, next) => {
  if (!isLogin && to.meta.auth) {
    next('/login')
  } else {
    next()
  }
})

用模式语言解释:

  • URL 即将变化

  • 路由系统拦截这次变化

  • 根据当前状态决定:

    • 放行

    • 或重定向

你可以总结一句:

beforeEach 并不是"跳转逻辑",

而是观察到路由状态变化前的一个统一决策点

四、Android 的 ARouter 在干什么?

1️⃣ ARouter 的关键设计

Kotlin 复制代码
@Route(path = "/order/detail")
public class OrderDetailActivity extends Activity {}
Kotlin 复制代码
ARouter.getInstance()
  .build("/order/detail")
  .navigation();

表面看是:

  • path → Activity

但本质是:

  • 路径字符串(路由状态)变化

  • 路由系统查表

  • 启动对应页面

2️⃣ ARouter 的拦截器(非常关键)

Kotlin 复制代码
public class LoginInterceptor implements IInterceptor {
    @Override
    public void process(Postcard postcard, InterceptorCallback callback) {
        if (!isLogin()) {
            callback.onInterrupt(new Exception("need login"));
        } else {
            callback.onContinue(postcard);
        }
    }
}

用观察者模式解释:

角色 对应
Subject 路由请求(Postcard)
Observer Interceptor
notify navigation()
update 是否放行 / 中断

ARouter 把"页面跳转"从 直接 startActivity

变成了 路径驱动 + 集中治理

五、Flutter go_router 放在同一条线上看

你前面已经讲过,这里只需要对齐抽象

Dart 复制代码
final router = GoRouter(
  refreshListenable: authState,
  redirect: ...
);
抽象 前端 ARouter go_router
路由状态 URL path location
被观察者 history 路由请求 authState / location
观察者 Router Interceptor GoRouter
守卫 beforeEach Interceptor redirect
页面切换 组件渲染 Activity Widget

一句话总结:

不同平台的路由系统,
都在监听某种"导航状态"的变化,
然后自动完成页面切换。

六、为什么三者都会"长成声明式路由"?

你可以在这一节点出演进原因

  • 页面数量变多

  • 入口变多(深链 / 推送 / 外部唤起)

  • 登录态 / 权限 / 灰度

  • 命令式跳转失控

最终都会走向:

集中路由表 + 统一守卫 + 状态驱动

七、"认知升维总结"(非常重要)

当我把前端路由、Android ARouter、Flutter go_router

放在同一个视角下看时,

才发现它们并不是三套不同的技术,

而是同一个设计模式在不同平台上的自然实现

理解这一点后,

学新框架不再是记 API,

而是识别模式。

相关推荐
@PHARAOH33 分钟前
WHAT - cursor cli 开发范式
前端·ai·ai编程
子兮曰1 小时前
深入 HTML-in-Canvas:当 Canvas 学会了渲染 DOM,前端图形生态要变天了
前端·javascript·canvas
ws_qy2 小时前
从大模型原理到前端 AI Coding 工程化实践
前端·ai编程
Lanren的编程日记2 小时前
Flutter 鸿蒙应用数据版本管理实战:版本记录+版本回退+版本对比,实现全链路数据版本控制
flutter·华为·harmonyos
倾颜2 小时前
React 19 源码主线拆解 04:Fiber 到底是什么,React 为什么需要 Fiber?
前端·react.js·源码阅读
AI攻城狮2 小时前
国产大模型能力大比拼,社区有话说
前端
IT_陈寒3 小时前
Vite的public文件夹放静态资源?这坑我替你踩了
前端·人工智能·后端
涵涵(互关)3 小时前
GoView各项目文件中的相关语法2
前端·javascript·vue.js
子兮曰3 小时前
别让爬虫白嫖你的导航站了:纯免费,手把手实现加密字体防爬
前端·javascript·后端
小村儿3 小时前
连载06 - Hooks 源码深度解析:Claude Code 的确定性自动化体系
前端·后端·ai编程