如何优雅的实现界面跳转 之 统跳协议
如何优雅的实现界面跳转 之 统跳协议
预热 – 我要解决的问题
首先我还是要推荐Gaosboy的这篇文章解耦神器 —— 统跳协议和Rewrite引擎
文章中,介绍了天猫app,基于文件配置和uri的页面跳转。这大大增加了app端的灵活性, 而这种实现很类似今天的前端或后端开发中的 静态路由 和 动态路由协议。
除了天猫,在很多的客户端架构的文章中,路由解耦的案例并不不少见,如携程移动App架构优化之旅
蘑菇街App的组件化之路
原生路由协议, 其实两年前就有了类似的实现。比如900+Star的HHRouter,而作者是当时还在布丁动画工作的Light。2015年我有幸见到本人,人很nice,并真是全栈。
DarwinNativeRouter 在接口设计上,很大程度上的参考了现有的react路由协议 react router。并且对原生跳转方式保留很大的可扩展性。所以我的初衷 DarwinNativeRouter 是一个足够轻量级的框架。Light & Flexible。
全局路由协议能解决的问题
错中复杂的Controller的跳转依赖
在iOS的世界里,传统的Controller跳转方式, A 跳转 B, 则 A 必须持有 B 的对象。 而在app长大的过程中, 势必会造成 A -> B , B -> C, A -> C D, E, F…
从而产生复杂的依赖链。全局的Router 使 A 不必依赖于 特定的 Controller 便可以实现跳转。
如下面跳转:
We Always Do:
UIViewController *personal = [UIViewController new];
personal.userId = @"10238372";
[self.navigationController pushViewController:personal animated:YES];
Router Code:
[[DNRouterrouter router]open:@"/user/10238372/profile"];
推送通知,点击打开指定页面
对于这种需求, 相信,目前最多的实现应该是两种, 一种的传参的Url, 而另一种,是传递int类型,并通过类似switch case对参数值的硬编码,实现跳转逻辑。
我是很反感第二种的跳转方式, 1. int毫无疑义, 只能硬解释。 2. 跳转的页面有限。 当然如果url采用硬编码, 也是跳转有限的。
而有了router,一切不一样。
从didFinishLaunchingWithOptions 和 didReceiveRemoteNotification捕获payload
跳用Router
Somethings we may do:
switch (type) {
case 1001:
//jumping code
break;
case 1002:
//jumping code
break;
case 1003:
//jumping code
break;
case 1004:
//jumping code
break;
default:
break;
}
Now we need do:
if([[DNRouter router]canOpen:url.absoluteString]) [[DNRouter router]open:url.absoluteString];
app间通讯 及 deeplink
Router 可以轻松handle deeplink。 deeplink 即: 从safari打开app的指定页面。 这方面做得比较好的, 如新浪微博的app, 在点击对应的新浪微博热点 条目时, 就发生了跳转,并跳到了条目详情。
Router, 同样可以被用作 app 间通讯, 和 deeplink 的原理相同。uri的通讯方式,被认为是最简单的app间通讯。 如我们常常使用的微信分享,配置的 scheme 就是用来做跳转和通讯的。
Router Code
- (BOOL)application:(UIApplication *)app openURL:(NSURL *)url options:(NSDictionary<NSString*, id> *)options
{
if([[DNRouter router]canOpen:url.absoluteString])
{
[[DNRouter router]open:url.absoluteString];
return YES;
}
return NO;
}
一致的行为处理, Hybrid & React Native
有了Router, 你可以使这些跳转 有一致的行为。
DarwinNativeRouter 特性
静态路由 /user
[DNRouter routerWithName:@"profile" path:@"/user"
navigationController:(UINavigationController *)self.window.rootViewController
controller:^__kindof UIViewController *{
UIViewController *controller = [[UIStoryboard storyboardWithName:@"Main" bundle:nil]instantiateViewControllerWithIdentifier:@"kMainBoard"];
return controller;
} action:^(__kindof UIViewController *controller) {
[DNDispatcher dispatcher].defaultNavigationController.animation(YES).pushViewController(controller);
}];
动态路由 /user/:id
[DNRouter routerWithName:@"profile" path:@"/user/:id"
navigationController:(UINavigationController *)self.window.rootViewController
controller:^__kindof UIViewController *{
UIViewController *controller = [[UIStoryboard storyboardWithName:@"Main" bundle:nil]instantiateViewControllerWithIdentifier:@"kMainBoard"];
return controller;
} action:^(__kindof UIViewController *controller) {
[DNDispatcher dispatcher].defaultNavigationController.animation(YES).pushViewController(controller);
}];
更方便的跳转,名称跳转 name jumping
[[DNRouter router]redirect:@"profile"];
相对路径跳转
//跟路径
[[DNRouter router]open:@"/user"];
//当前路径
[[DNRouter router]open:@"./user"];
//上一级
[[DNRouter router]open:@"../user"];
易扩展, 自定义跳转 action
[DNRouter routerWithName:@"profile" path:@"/user/:id"
navigationController:(UINavigationController *)self.window.rootViewController
controller:^__kindof UIViewController *{
UIViewController *controller = [[UIStoryboard storyboardWithName:@"Main" bundle:nil]instantiateViewControllerWithIdentifier:@"kMainBoard"];
return controller;
} action:^(__kindof UIViewController *controller) {
[DNDispatcher dispatcher].defaultNavigationController.animation(YES).pushViewController(controller);
}];
默认行为,及 异常处理,index & 404
// index page
[DNRouter defaultRouterWithController:^__kindof UIViewController *{
} action:^(__kindof UIViewController *controller) {
}];
// 404 page
[DNRouter notFoundRouterWithController:^__kindof UIViewController *{
} action:^(__kindof UIViewController *controller) {
}];
后言
DarwinNativeRouter 现在还没有到1.0版本,还有很多可以想象的东西,欢迎让他更加完善,和提pr。
DarwinNativeRouter’s Github
如何优雅的实现界面跳转 之 统跳协议相关推荐
- 如何优雅的实现界面跳转 之 统跳协议 - DarwinNativeRouter
PS 感谢大家的关注,由于我本想开源4个库,除了router, 另外三个分别是native dispatcher, web dispatcher 和 react dispatcher , 所以rout ...
- java等待欢迎界面_android welcome欢迎界面3秒后自动跳转
android welcome欢迎界面3秒钟之后自动跳转其实就是将APP的启动页面设置成我们自定义的Activity,而不是原来的MainActivity,方法很简单,如下是详细步骤. 第一步:自定义 ...
- 【Android】用户登录界面功能实现:登陆跳转、退出
文章目录 用户登录界面功能实现:登陆跳转.退出 ♦ 回顾 ♦ 编写 MainActivity 实现功能 登录功能效果 退出弹框.连续点击返回退出 ♦ 设计 activity_my_tool.xml 展 ...
- 两种控制器的跳转与回跳
第一种:用于任何控制器的跳转, - (void)presentViewController:(UIViewController *)viewControllerToPresent animated: ...
- 快手跳转微信,快手跳转微信怎么做
快手跳转微信,快手跳转微信怎么做?抖音/快手私信跳转微信名片使用效果#抖音卡片#抖音名片#引流方法 快手怎么绑定微信演示机型,荣耀 30S 试用系统,麦杰克 UI 三点一点一软件版本,快手 8 点一零 ...
- java 跳表_数据结构跳表学习并用Java实现
前面学习很多类的源码过程中,底层基本都是数组和链表,今天学习第三种结构跳表(SkipList). 跳表解决的问题 一个有序的数组如果我们要判断一个数据是否存在可以通过二分查找法非常快速的判断出来,但是 ...
- 7、斐波那契数列、跳台阶、变态跳台阶、矩形覆盖------------剑指offer系列
题目:斐波那契数列 大家都知道斐波那契数列,现在要求输入一个整数n,请你输出斐波那契数列的第n项(从0开始,第0项为0). f(n) = f(n-1) + f(n-2) 基本思路 这道题在剑指offe ...
- jsp超链接中怎么跳转页面跳转_JSP页面跳转方法小结
实现JSP页面跳转,有如下几种方式: n 使用href超链接标记 (客户端跳转) n 使用JavaScript ...
- 【Android 逆向】IDA 工具使用 ( 重命名函数 | 添加注释 | 添加标签 / 跳转标签 | 代码跳转前进 / 后退 )
文章目录 一.重命名函数 二.添加注释 三.添加标签 / 跳转标签 四.代码跳转前进 / 后退 一.重命名函数 针对一个 匿名函数 , 在分析函数时 , 可以为匿名函数进行命名 ; 右键点击 函数名 ...
最新文章
- php中 继承中的概念,JavaScript_JavaScript中的继承方式详解,js继承的概念
js里常用的如下 - phpStudy...
- 成功解决‘pip‘ 不是内部或外部命令,也不是可运行的程序 或批处理文件
- java内部类的作用
- kettle 的表输出 table output
- leetcode 141. 环形链表(快慢指针解法)
- Java Web项目,Android和微信小程序的初始页面配置
- sqlDataAdapter的FillSchema用法
- vue中使用Ueditor编辑器 -- 1
- 【RabbitMQ】6、rabbitmq生产者的消息确认
- 【转载保存】Jsoup解析html常用方法
- Python工作笔记-仿大佬的list赋值
- C++基础与深度解析第五章: 语句
- 自编码模型autoencoder
- 数学建模笔记(十):博弈模型
- 一筐鸡蛋c语言编程,求答案-求答案?一筐鸡蛋?求答案?一筐鸡蛋:1个1个拿,正好拿完2个2 爱问知识人...
- 四川大学计算机与生命科学专业,四川大学生命科学学院2014年研招专业目录
- vue-composition-api.mjs:1:7: ERROR: No matching export in “node_modules/vue/dist/vue.runtime.esm-bun
- isbn书号查询php代码,php根据isbn书号查询amazon网站上的图书信息的示例_PHP教程
- libreCAD使用
- Microsoft office 2007 word PPT 转pdf的插件