目前iOS常用路由框架是JLRouter、HHRouter、MGJRouter。

但是这些路由库都各有不足,首先是JLRouter,用不到的功能繁多,而且基于遍历查找URL,效率低下。HHRouter耦合程度太高,过度依赖ViewController。MGJRouter功能太过简单。

今天介绍一个新发现的iOS路由框架,FFRouter:

FFRouter 是 iOS 中一个强大且易用的 URL 路由框架,支持 URL Rewrite,使 APP 在发布之后也可以动态修改相关路由逻辑。基于匹配查找 URL,效率高。集成和使用都非常简单!

Github链接:FFRouter

功能

  • 具备基本的 URL 注册、Route、取消注册、打印 Log 等
  • 支持使用通配符(*)注册 URL
  • 支持 URL Rewrite
  • 支持 Rewrite 时获取原 URL 参数或 URLComponents,并可对其进行URL Encode或 Decode
  • 支持通过 URL 获取 Object
  • 支持 Route URL 时传递非常规对象
  • 支持 Route 一个未注册的 URL 时统一回调

安装

CocoaPods

  1. target 'MyApp' do
  2. pod 'FFRouter'
  3. end

运行 pod install

手动安装

添加其中的 FFRouter 文件夹到自己项目

使用方法

首先

  1. #import "FFRouter.h"
1、基本使用
  1. /**
  2. 注册 url
  3. @param routeURL 要注册的 URL
  4. @param handlerBlock URL 被 Route 后的回调
  5. */
  6. + (void)registerRouteURL:(NSString *)routeURL handler:(FFRouterHandler)handlerBlock;
  7. /**
  8. 注册 URL,通过该方式注册的 URL 被 Route 后可返回一个 Object
  9. @param routeURL 要注册的 URL
  10. @param handlerBlock URL 被 Route 后的回调,可在回调中返回一个 Object
  11. */
  12. + (void)registerObjectRouteURL:(NSString *)routeURL handler:(FFObjectRouterHandler)handlerBlock;
  13. /**
  14. 判断 URL 是否可被 Route(是否已经注册)
  15. @param URL 要判断的 URL
  16. @return 是否可被 Route
  17. */
  18. + (BOOL)canRouteURL:(NSString *)URL;
  19. /**
  20. Route 一个 URL
  21. @param URL 要 Router 的 URL
  22. */
  23. + (void)routeURL:(NSString *)URL;
  24. /**
  25. Route 一个 URL,并带上额外参数
  26. @param URL 要 Router 的 URL
  27. @param parameters 额外参数
  28. */
  29. + (void)routeURL:(NSString *)URL withParameters:(NSDictionary<NSString *, id> *)parameters;
  30. /**
  31. Route 一个 URL,可获得返回的 Object
  32. @param URL 要 Router 的 URL
  33. @return 返回的 Object
  34. */
  35. + (id)routeObjectURL:(NSString *)URL;
  36. /**
  37. Route 一个 URL,并带上额外参数,可获得返回的 Object
  38. @param URL 要 Router 的 URL
  39. @param parameters 额外参数
  40. @return 返回的 Object
  41. */
  42. + (id)routeObjectURL:(NSString *)URL withParameters:(NSDictionary<NSString *, id> *)parameters;
  43. /**
  44. Route 一个未注册 URL 时回调
  45. @param handler 回调
  46. */
  47. + (void)routeUnregisterURLHandler:(FFRouterUnregisterURLHandler)handler;
  48. /**
  49. 取消注册某个 URL
  50. @param URL 要被取消注册的 URL
  51. */
  52. + (void)unregisterRouteURL:(NSString *)URL;
  53. /**
  54. 取消注册所有 URL
  55. */
  56. + (void)unregisterAllRoutes;
  57. /**
  58. 是否显示 Log,用于调试
  59. @param enable YES or NO,默认为 NO
  60. */
  61. + (void)setLogEnabled:(BOOL)enable;
【备注】

(1)注册 URL:

  1. [FFRouter registerRouteURL:@"protocol://page/routerDetails/:id" handler:^(NSDictionary *routerParameters) {
  2. //Route的URL与本次注册URL匹配时的回调
  3. }];
  4. [FFRouter registerRouteURL:@"wildcard://*" handler:^(NSDictionary *routerParameters) {
  5. //Route的URL与本次注册URL匹配时的回调
  6. }];
  7. [FFRouter registerRouteURL:@"protocol://page/routerObjectDetails" handler:^(NSDictionary *routerParameters) {
  8. //Route的URL与本次注册URL匹配时的回调
  9. }];

可通过routerParameters获取 URL 中的参数,routerParameters[FFRouterParameterURLKey]为完整的URL.



(2)当需要通过以下方法:

  1. + (id)routeObjectURL:(NSString *)URL;

Route 一个 URL 并获取返回值时,需要使用如下方法注册 URL:

  1. + (void)registerObjectRouteURL:(NSString *)routeURL handler:(FFObjectRouterHandler)handlerBlock;

并在 handlerBlock 中返回需要返回的 Object,例如:

  1. //注册并返回必要的值
  2. [FFRouter registerObjectRouteURL:@"protocol://page/routerObjectDetails" handler:^id(NSDictionary *routerParameters) {
  3. NSString *str = @“根据需要返回必要的Object”;
  4. return str;
  5. }];
  6. //获取返回的值
  7. NSString *ret = [FFRouter routeObjectURL:@"protocol://page/routerObjectDetails"];

(3)如果需要传递非常规对象作为参数,如UIImage等,可使用如下方式:

  1. [FFRouter routeURL:@"protocol://page/routerDetails?nickname=imlifengfeng" withParameters:@{@"img":[UIImage imageNamed:@"router_test_img"]}];
2、URL Rewrite
  1. /**
  2. 根据设置的 Rules 去 rewrite 一个 URL
  3. @param url 将被 rewrite 的 URL
  4. @return rewrite 后的 URL
  5. */
  6. + (NSString *)rewriteURL:(NSString *)url;
  7. /**
  8. 添加一个 RewriteRule
  9. @param matchRule 正则匹配规则
  10. @param targetRule 转换规则
  11. */
  12. + (void)addRewriteMatchRule:(NSString *)matchRule targetRule:(NSString *)targetRule;
  13. /**
  14. 同时添加多个 RewriteRule,格式必须为:@[@{@"matchRule":@"YourMatchRule",@"targetRule":@"YourTargetRule"},...]
  15. @param rules RewriteRules
  16. */
  17. + (void)addRewriteRules:(NSArray<NSDictionary *> *)rules;
  18. /**
  19. 移除一个 RewriteRule
  20. @param matchRule 将被移除的 matchRule
  21. */
  22. + (void)removeRewriteMatchRule:(NSString *)matchRule;
  23. /**
  24. 移除所有 RewriteRule
  25. */
  26. + (void)removeAllRewriteRules;
【备注】

(1)可以使用正则添加一条 Rewrite 规则,例如:

要实现打开 URL:https://www.taobao.com/search/原子弹时,将其拦截,改用本地已注册的 URL:protocol://page/routerDetails?product=原子弹打开。

首先添加一条 Rewrite 规则:

  1. [FFRouterRewrite addRewriteMatchRule:@"(?:https://)?www.taobao.com/search/(.*)" targetRule:@"protocol://page/routerDetails?product=$1"];

之后在打开URL:https://www.taobao.com/search/原子弹时,将会 Rewrite 到URL:protocol://page/routerDetails?product=原子弹

  1. [FFRouter routeURL:@"https://www.taobao.com/search/原子弹"];

(2)可以通过以下方法同时增加多个规则:

  1. + (void)addRewriteRules:(NSArray<NSDictionary *> *)rules;

其中 rules 格式必须为以下格式:

  1. @[@{@"matchRule":@"YourMatchRule1",@"targetRule":@"YourTargetRule1"},
  2. @{@"matchRule":@"YourMatchRule2",@"targetRule":@"YourTargetRule2"},
  3. @{@"matchRule":@"YourMatchRule3",@"targetRule":@"YourTargetRule3"},]

(3)Rewrite 规则中的保留字:

  • 通过 $scheme$host$port$path$query$fragment 获取标准 URL 中的相应部分。通过$url获取完整 URL
  • 通过 $1$2$3...获取matchRule的正则中使用圆括号取出的参数
  • $:原变量的值、$$:原变量URL Encode后的值、$#:原变量URL Decode后的值

例如:

https://www.taobao.com/search/原子弹对于Rewrite 规则(?:https://)?www.taobao.com/search/(.*)

  1. $1=原子弹
  2. $$1=%e5%8e%9f%e5%ad%90%e5%bc%b9

同样,https://www.taobao.com/search/%e5%8e%9f%e5%ad%90%e5%bc%b9对于Rewrite 规则(?:https://)?www.taobao.com/search/(.*)

  1. $1=%e5%8e%9f%e5%ad%90%e5%bc%b9
  2. $#1=原子弹
2、FFRouterNavigation

考虑到经常用路由配置UIViewController之间的跳转,所以增加了额外的工具FFRouterNavigation来更方便地控制UIViewController之间的跳转。具体使用方法如下:

  1. /**
  2. push 时是否自动隐藏底部TabBar
  3. @param hide 是否自动隐藏,默认为 NO
  4. */
  5. + (void)autoHidesBottomBarWhenPushed:(BOOL)hide;
  6. /**
  7. 获取当前 ViewController
  8. @return 当前 ViewController
  9. */
  10. + (UIViewController *)currentViewController;
  11. /**
  12. 获取当前 NavigationViewController
  13. @return return 当前 NavigationViewController
  14. */
  15. + (nullable UINavigationController *)currentNavigationViewController;
  16. /**
  17. Push ViewController
  18. @param viewController 被 Push 的 ViewController
  19. @param animated 是否使用动画
  20. */
  21. + (void)pushViewController:(UIViewController *)viewController animated:(BOOL)animated;
  22. /**
  23. Push ViewController,可设置当前 ViewController 是否还保留
  24. @param viewController 被 Push 的 ViewController
  25. @param replace 当前 ViewController 是否还保留
  26. @param animated 是否使用动画
  27. */
  28. + (void)pushViewController:(UIViewController *)viewController replace:(BOOL)replace animated:(BOOL)animated;
  29. /**
  30. Push 多个 ViewController
  31. @param viewControllers ViewController Array
  32. @param animated 是否使用动画
  33. */
  34. + (void)pushViewControllerArray:(NSArray *)viewControllers animated:(BOOL)animated;
  35. /**
  36. present ViewController
  37. @param viewController 被 present 的 ViewController
  38. @param animated 是否使用动画
  39. @param completion 回调
  40. */
  41. + (void)presentViewController:(UIViewController *)viewController animated:(BOOL)animated completion:(void (^ __nullable)(void))completion;
  42. /**
  43. 关闭当前 ViewController,push、present 方式通用
  44. @param animated 是否使用动画
  45. */
  46. + (void)closeViewControllerAnimated:(BOOL)animated;

比JLRoutes更强大更好用的iOS开源路由框架—FFRouter的更多相关文章

  1. 安装更强大更美观的zsh,配置oh my zsh及插件

    安装更强大更美观的zsh,配置oh my zsh及插件 #0x0 安装zsh #0x1 安装oh my zsh #0x2 配置zshrc #0x3 配置主题 #0x4 安装插件 #0x5 小结 #0x ...

  2. Python的regex模块——更强大的正则表达式引擎

    Python自带了正则表达式引擎(内置的re模块),但是不支持一些高级特性,比如下面这几个: 固化分组    Atomic grouping 占有优先量词    Possessive quantifi ...

  3. 思维导图软件TheBrain 8全新发布 提供更强大的信息管理

    TheBrain思维导图软件是全球唯一一款动态的网状结构的思维导图软件,广泛用于学习.演讲.项目管理.会议.需求调研与分析等.其独特的信息组织方式使得用户可以创建并连接到数以万计的数字想法,为此在全球 ...

  4. cVim—Chrome上更强大的vim插件

    cVim——Chrome上更强大的vim插件 介绍 也许很多人在chrome上都用过类似Vimium, ViChrome的插件,这些插件的目的都差不多,就是在浏览器中提供一些类似vim的操作来提高效率 ...

  5. 功能更强大的格式化工具类 FormatUtils.java

    package com.util; import java.text.DecimalFormat; import java.text.ParseException; import java.text. ...

  6. 10个工具让你的 shell 脚本更强大

    10个工具让你的 shell 脚本更强大 很多人误以为shell脚本只能在命令行下使用.其实shell也可以调用一些GUI组件,例如菜单,警告框,进度条等等.你可以控制最终的输出,光标位 置还有各种输 ...

  7. powerMock比easyMock和Mockito更强大(转)

    powerMock是基于easyMock或Mockito扩展出来的增强版本,所以powerMock分两种类型,如果你习惯于使用easyMock的,那你就下载基于easyMock的powerMock,反 ...

  8. 让Docker功能更强大的10个开源工具

    让Docker功能更强大的10个开源工具 更好的管理.Web前端程序.更深入地了解容器应用程序,Docker生态系统正在迅速发展,这还得归功于其充满活力的开源社区. 软件项目的成功常常根据其催生的生态 ...

  9. summerDao-比mybatis更强大无需映射配置的dao工具

    summerDao是summer框架中的一个数据库操作工具,项目地址:http://git.oschina.net/xiwa/summer. 怎么比mybatis更强大,怎么比beetlsql更简单, ...

随机推荐

  1. jeesite 简介

    jeesite 简介 https://github.com/thinkgem/jeesite http://jeesite.com/

  2. [PHP]怎样在SAE的CodeIgniter项目中隐藏掉index.php

    第一步:改动项目根文件夹的config.yaml文件.加入例如以下内容: handle: - rewrite: if(!is_dir() && !is_file() && ...

  3. hdoj--2709--Sumsets(数位dp)

    Sumsets Time Limit: 6000/2000 MS (Java/Others)    Memory Limit: 32768/32768 K (Java/Others) Total Su ...

  4. [JSOI2008] [BZOJ1567] Blue Mary的战役地图 解题报告 (hash)

    题目链接:https://www.lydsy.com/JudgeOnline/problem.php?id=1567 Description Blue Mary最近迷上了玩Starcraft(星际争霸 ...

  5. python-深拷贝-浅拷贝

    python-深拷贝-浅拷贝 标签(空格分隔): 未分类 浅拷贝: 拷贝了引用,并没有拷贝内容 深拷贝: 深拷贝是对于一个对象所有层次的拷贝(递归)

  6. 【DotNetNuke介绍】

    简介 DotNetNuke(以下简称DNN)的最终目的是创建一个门户的框架平台,这个平台可以为开发者增添模块搭建应用程序提供坚实的可靠的支持.应用程序的一个关键的功能就是数据存取..NET Frame ...

  7. manacherO(n)求最长回文子串 hihocoder1032

    原文地址:https://segmentfault.com/a/1190000003914228   http://blog.csdn.net/synapse7/article/details/189 ...

  8. ReactiveCocoa结合了几种编程风格

    函数式编程(Functional Programming):使用高阶函数,例如函数用其他函数作为参数.响应式编程(Reactive Programming):关注于数据流和变化传播.所以,你可能听说过 ...

  9. 爬虫--pyquery使用

    强大又灵活的网页解析库. 初始化   字符串初始化 html = ''' <div> <ul> <li class="item-0">first ...

  10. 01背包-第k优解

    The title of this problem is familiar,isn't it?yeah,if you had took part in the "Rookie Cup&quo ...