WLRRoute: 一个移动端路由

看了一篇关于移动端路由的文章一步步构建iOS路由, 感觉写的多, 写的也很好, 所以我决定去看看源码, 在用我自己的语言来重新总结一下.

其实说到路由, 不由得就想起了组件化, 但是这两者是有本质化区别的, 路由只是实现组件化甚至插件化的一种手段而已, 作者之前也写过一篇关于组件化的文章, 就不多说了.

路由的作用在我看来就是把 任务/行为 都封装成一个一个请求,或者我们称之为任务. 然后由路由器统一管理和处理, 从而就可以很好地监听任务的执行.

其实更极端点的说法就是路由器就是一个任务调度中心, 我们可以获取整个任务的前因和后果, 其实这里是一个打印 log 的好地方, 集中处理记录所有的行为. 当然我们如果通过中间件这种方式来操作.

大家可以先看看原作者的博文, 再来看我这个狗尾续貂之作.

简单说一下路由器的工作流吧

  1. 首先我们获取到一个 url, 可以是 内部调用 也可以是外部调用, https://www.abc.com/123, action://doSomething 这其中包括两个部分 scheme 和 path, 我们在适配的时候会根据这两部分得到对应的 handler
  2. 我们向路由器根据 url 注册 handler 和 blockHandler, 这里的 url 支持正则和如有参数, 以代码中的例子
    [self.router registerHandler:[[WLRSignHandler alloc]init] forRoute:@"/signin/:phone([0-9]+)"];
    
  3. 我们还可以设置一些满足 WLRRouteMiddleware 协议的中间件, 来处理和终止我们的每次 request
  4. 之前都是一些配置工作,现在我们开始正式的工作流
  5. WLRRouter 去 handler 对应的 url, 如果 被适配器 WLRRouteMatcher适配到, 则生成对应的 WLRRouteRequest, 否则结束任务.
  6. 用所有的中间件依次处理 WLRRouteRequest, 发生错误或者任务被中间件中断则结束
  7. 找到对应的 handler 来执行 WLRRouteRequest

更细节的东西我建议大家去看源码,或者 WLRRoute 作者的博客.

一些思考和改善

首先说现在的功能其实已经可以满足大多数的使用场景, 但是如果我们把路由看做一个功能强大的任务调度中心的话, 那么就引出了下面的我的一系列思考和问题.
具体的解决方案我就不说了, 我希望大家自己想一下, 我提出的这些问题是否是有必要的, 如果有必要, 应该如何设计代码?

中间件的优化?

目前的中间件能做的事情就是在任务开始之前得到 request , 然后进行操作, 可以返回结果结束任务, 或者直接抛出错误.
但是, 我们的任务不仅仅是推出一个新的界面的话, 如果也包括执行一段逻辑的话, 那么是否中间件也要对 request 的 reponse 进行处理呢? 比如判断逻辑执行的效率, 计算执行时间等等.
在我的想法中, 中间件是这么执行的, 感觉可以做很多事情的样子

- Middleware1
   - Middleware2
       - handler
    -Middleware2
- Middleware1

任务异步执行?

其实现在作者是有任务执行的, 是使用 block 的时候, 但是在我看来其实都不应该分 block 和 handler, 应该都封装成 handler, 换句话暴露在外面的 block 接口只是一个语法糖, 里面改成 同时支持同步和异步执行的 handler

添加上下文 Context?

移动端路由一个很大的不同就是传递参数比较纠结, 如果只通过 url, 我们只能传递一些字符串参数, 不能传递对象. 尤其是在 app 内唤起路由的时候, 往往传递对象参数是一个很重要的需求.
庆幸的是,我们的请求被封装成了 WLRRouteRequest, 那么是否可以让这个对象持有这些参数, 在 handler 中直接读取呢?
那么继续想下去, 我们其实有可能在处理任务的时候需要很多参数,有些参数可能是一些环境参数,把所有东西都放到 request 中? 我在想, 是否可以给每个 request 创建 一个 context, 然后把这些参数都赋值给 上下文呢

所有请求都使用统一的中间件?

目前, 我们的所有中间件都是全局的, 但是可能我你需要所有请求都执行对应的中间件呢?
我其实期望的是可以针对对应的适配器添加对应的中间件, 比如我有一些任务是对数据库的操作, 那么我系网针对这些任务添加记录时间的中间件.

组适配器?

如果我们有几个任务的 url 的前缀相同, 我们是否可以先通过前缀得到一个
WLRGroupRouteMatcher, 然后再一一添加子适配器的 handler, 我认为这样的话可能逻辑更清晰, 而且可以做很多封装, 把复杂的需要重复添加事情放到这里面.

适配器的效率问题?

现在库中的适配器是每次遍历, 那么当适配器很多的时候, 肯定会发生效率问题, 那么我们是否可以根据 scheme, 前缀, 某一个通用参数甚至是传进来一个参数来提高我们适配的效率呢

异步的优化?

如果我们添加了很多异步 handler, 有两个问题必然会出现
1 异步的调度, 我们需要使用 NSOperation 或者 GCD
2 在一个异步路由任务中创建了一个新的异步路由任务

结语

好吧,好吧,我都知道,我们在移动端可能根本就不需要一个这么复杂的路由器.
这个听着更像是一个后端的网络框架的雏形.
但是我想说的是, 闲着也是闲着, 随便瞎想想呗.

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 217,542评论 6 504
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,822评论 3 394
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 163,912评论 0 354
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,449评论 1 293
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,500评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,370评论 1 302
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,193评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,074评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,505评论 1 314
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,722评论 3 335
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,841评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,569评论 5 345
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,168评论 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,783评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,918评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,962评论 2 370
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,781评论 2 354

推荐阅读更多精彩内容