- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章iOS使用核心的50行代码撸一个路由组件由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
使用组件化是为了解耦处理,多个模块之间通过协议进行交互。而负责解析协议,找到目的控制器,或者是返回对象给调用者的这个组件就是路由组件。本文讲解如何使用核心的50行代码实现一个路由组件.
路由注册实现 路由使用实现 。
组件化和路由 。
之前看过挺多的关于路由管理、路由处理的文章,常常会和组件化出现在一起,一开始不知道为何路由和组件化出现在一起,后来公司的项目中使用了路由组件(他本身也是一个组件,确切的说是一个中间人或者中介者),才突然想明白了,原来如此.
使用组件化是为了解耦处理,多个模块之间通过协议进行交互。而负责解析协议,找到目的控制器,或者是返回对象给调用者的这个组件就是路由组件.
路由组件的职责主要是:
注册者传递path和path对应的block,block的具体实现又注册者自己处理 。
调用者最简单可以传递一个path给路由组件发起调用,路由组件会把具体的处理转发给注册者,理论上是可以任意的操作,包括页面跳转、弹窗提示、返回一个值给调用者等 。
下面会会在以上分析的基础上实现一个简单的路由组件,对应的代码可以在ytrouterdemo这里找到 。
路由的实现 。
路由的实现包括两部分:路由注册实现以及路由使用实现 。
路由注册实现 。
路由注册实现时序图:
如上图所示,步骤很简单:
以上步骤对应的代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
|
- (
void
)registerpath:(nsstring *)path actionblock:(routeractionblock)actionblock {
ytrouteractionobject *actionobject = [ytrouteractionobject
new
];
actionobject.path = path;
actionobject.actionblock = actionblock;
nsmutabledictionary *subrouter = [self subroutermapwithpath:path];
subrouter[ytrouteractionobjectkey] = actionobject;
}
- (nsmutabledictionary *)subroutermapwithpath:(nsstring *)path {
nsarray *components = [path componentsseparatedbystring:@
"/"
];
nsmutabledictionary *subrouter = self.routermap;
for
(nsstring *component in components) {
if
(component.length == 0) {
continue
;
}
if
(!subrouter[component]) {
subrouter[component] = [nsmutabledictionary
new
];
}
subrouter = subrouter[component];
}
return
subrouter;
}
|
在demo中注册的几个路由最终的配置如下,比如home/messagelist对应的路由配置保存在<ytrouteractionobject: 0x6040000365e0>对象中 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
printing description of self->_routermap:
{
home = {
"_"
=
"<ytrouteractionobject: 0x60c00003b040>"
;
messagelist = {
"_"
=
"<ytrouteractionobject: 0x6040000365e0>"
;
detail = {
"_"
=
"<ytrouteractionobject: 0x600000038ec0>"
;
};
getmessage = {
"_"
=
"<ytrouteractionobject: 0x600000038e80>"
;
};
};
};
}
|
路由使用实现 。
路由使用实现时序图:
如上图所示,步骤很简单:
从注册的配置中找到匹配的ytrouteractionobject对象 。
执行ytrouteractionobject对象的actionblock,会传递一个ytrouteractioncallbackobject对象,如果调用者需要的是返回值,可以使用ytrouteractioncallbackobject对象的actioncallbackblock传递一个返回值,这个actionblock是又业务方的注册者实现的 。
以上步骤对应的代码如下:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
|
- (
bool
)runwithactioncallbackobject:(ytrouteractioncallbackobject *)actioncallbackobject {
// 判断是否支持scheme
if
(![self canacceptscheme:actioncallbackobject.uri.scheme]) {
return
no;
}
// 获取path对应的actionobject
ytrouteractionobject *actionobject = [self actionobjectwithpath:actioncallbackobject.uri.path];
// 执行path注册的对应block
!actionobject.actionblock ?: actionobject.actionblock(actioncallbackobject);
return
yes;
}
- (ytrouteractionobject *)actionobjectwithpath:(nsstring *)path {
nsmutabledictionary *subrouter = [self subroutermapwithpath:path];
return
subrouter[ytrouteractionobjectkey];
}
|
客户端的使用 。
以上讲到了核心的路由注册实现和路由使用实现,总共代码还没有50行,所以还是很简单的,接下来会讲下客户端的使用步骤,包括 。
客户端注册者注册 。
注册的时机需要比较找,考虑到集成的方便,选择在load方法中处理路由注册,如下代码所示,添加了几个测试的路由,分两种情况来说明下使用 。
1、不需要返回值 。
如下注册"home/messagelist"的是一个页面跳转的路由,actionblock的参数是一个ytrouteractioncallbackobject对象,可以从ytrouteractioncallbackobject对象或者到参数,关于如何传递值,会在下面的客户端调用者使用这里讲到。然后在actionblock处理目的页面的初始化、参数设置等步骤,然后执行页面跳转.
2、需要返回值 。
如下注册"home/messagelist/getmessage"的是一个提供返回值的路由,同样也可以从ytrouteractioncallbackobject对象获取参数,另外ytrouteractioncallbackobject对象还有一个actioncallbackblock属性是专门处理返回参数给调用者的,如下的代码只是简单返回一个字符串,在更加具体的业务场景中,这里会设置接口调用、数据库查询等任务,最后把结果返回.
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
@implementation moduleauriregister
+ (
void
)load {
[[ytroutermanager sharedroutermanager] registerpath:@
"home/messagelist"
actionblock:^(ytrouteractioncallbackobject *callbackobject) {
messagelistviewcontroller *messagelistvc = [messagelistviewcontroller
new
];
nsstring *title = callbackobject.uri.params[@
"title"
];
messagelistvc.title = title;
[[uiviewcontroller yt_currentviewcontrolloer].navigationcontroller pushviewcontroller:messagelistvc animated:yes];;
}];
[[ytroutermanager sharedroutermanager] registerpath:@
"home/"
actionblock:^(ytrouteractioncallbackobject *callbackobject) {
}];
[[ytroutermanager sharedroutermanager] registerpath:@
"home/messagelist/detail"
actionblock:^(ytrouteractioncallbackobject *callbackobject) {
}];
[[ytroutermanager sharedroutermanager] registerpath:@
"home/messagelist/getmessage"
actionblock:^(ytrouteractioncallbackobject *callbackobject) {
// 内容回调
!callbackobject.actioncallbackblock ?: callbackobject.actioncallbackblock(@
"message content text demo"
);
}];
}
@end
|
客户端调用者使用 。
1、简单的path跳转调用 。
使用ytroutermanager单例对象的runwithpath方法,传递一个注册的path参数完成跳转.
1
2
3
|
[self addactionwithtitle:@
"router页面跳转"
detailtext:@
"home/messagelist"
callback:^{
[[ytroutermanager sharedroutermanager] runwithpath:@
"home/messagelist"
];
}];
|
2、使用url调用和有url参数的调用 。
使用ytroutermanager单例对象的runwithurlstring方法,传递一个完整的包含了scheme/path,或者有参数的会才有参数的url,比如"ytrouter://home/messagelist" 和 "ytrouter://home/messagelist?title=hello message" ,路由组件会解析出里面的scheme、path、params,进行scheme过滤处理、path查询ytrouteractionobject对象处理、参数传递处理.
1
2
3
4
5
6
|
[self addactionwithtitle:@
"router使用url调用"
detailtext:@
"ytrouter://home/messagelist"
callback:^{
[[ytroutermanager sharedroutermanager] runwithurlstring:@
"ytrouter://home/messagelist"
];
}];
[self addactionwithtitle:@
"router使用带参数的url调用"
detailtext:@
"ytrouter://home/messagelist?title=hello message"
callback:^{
[[ytroutermanager sharedroutermanager] runwithurlstring:@
"ytrouter://home/messagelist?title=hello message"
];
}];
|
效果如下图所示:
效果图 。
3、简单的path跳转调用 。
使用ytroutermanager单例对象的runwithactioncallbackobject方法,传递一个ytrouteractioncallbackobject类型的参数,设置ytrouteractioncallbackobject对象的uri和结果回调actioncallbackblock参数,在actioncallbackblock中处理返回值.
1
2
3
4
5
6
7
8
9
10
11
|
[self addactionwithtitle:@
"router获取返回值"
detailtext:@
"home/messagelist/getmessage"
callback:^{
__block id message = nil;
ytrouteractioncallbackobject *actioncallbackobject = [ytrouteractioncallbackobject
new
];
actioncallbackobject.uri = [[yturi alloc] initwithpath:@
"home/messagelist/getmessage"
];
actioncallbackobject.actioncallbackblock = ^(id result) {
message = result;
};
[[ytroutermanager sharedroutermanager] runwithactioncallbackobject:actioncallbackobject];
nslog(@
"message = %@"
, message);
}];
|
一些小想法 。
总结 。
以上所述是小编给大家介绍的ios使用核心的50行代码撸一个路由组件,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对我网站的支持! 。
原文链接:https://my.oschina.net/FEEDFACF/blog/2088242 。
最后此篇关于iOS使用核心的50行代码撸一个路由组件的文章就讲到这里了,如果你想了解更多关于iOS使用核心的50行代码撸一个路由组件的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我的 Angular 应用程序中有以下代码。 app.config(function($routeProvider, $locationProvider) { $locationProvider
这就是我在 Backbone 中进行路由的方式,在决定调用哪个外部模板之前,首先获取路由及其参数。我觉得这很灵活。 var Router = Backbone.Router.extend({
我是 MEAN 堆栈领域的新手,我对 Angular 路线有一些疑问。为什么我应该在客户端重新创建后端已经用express.js创建的路由,有什么好处?这是 Angular.js 工作的唯一方式吗?我
我可以设置一条从根级 URL 进行映射的路由吗? http://localhost:49658/ 我使用的是 VS2010 内置 Web 服务器。 尝试使用空白或单斜杠 URL 字符串设置路由不起作用
我有一个现有的应用程序 Rails 3.2.17和 Angular js。我想在现有应用程序中包含 Activeadmin。 我遵循了 active-admin post from ryan bate
我正在关注 this Angular 中的路由教程,它就是行不通。当我使用“comp”选择器放置它的 HTML 代码时,它可以工作,但是当我尝试使用路由器 socket 对其进行路由时,它只显示来自
多个路由通过路由器进行管理。 前端路由的概念和原理 (编程中的) 路由 (router)就是一组 key-value 对应关系,分为:后端路由和前端路由 后端路由
服务器需要根据不同的URL或请求来执行不一样的操作,我们可以通过路由来实现这个步骤。 第一步我们需要先解析出请求URL的路径,我们引入url模块。 我们来给onRequest()函数加上一些逻辑
我正在为 Angular 6 应用程序设置路由,我想要一条可以匹配可变数量的段的路由。目前我有一个看起来像这样的路由配置: const routes: Routes = [ { path: '',
用户将点击电子邮件中的链接,如下所示: do-something/doSomething?thing=XXXXXXXXXXX 如何在路由器中定义路由并订阅获取参数? 目前在我的路由器中: {
我有一个具有以下结构的 Angular (4) 应用程序: app.module bi.module auth.module 路由应该是: / -> redirect to /home /
我正在使用 WCF 4 路由服务,并且需要以编程方式配置服务(而不是通过配置)。我见过的这样做的例子很少见,创建一个 MessageFilterTable 如下: var fi
我需要创建一个“路由”服务。我正在尝试使用 .Net 的 System.ServiceModel.Routing.IRequestReplyRouter我可以让它只在 HTTP 模式下工作,而不是在
例如,链接: /shop/phones/brend/apple/display/retina/color/red 在哪里: phones - category alias brend -
非常基本的问题,我很惊讶我找不到答案。我刚刚开始研究 django 并进行了开箱即用的安装。创建了一个项目并创建了一个应用程序。 urls.py 的默认内容很简单: urlpatterns = [
我已经实现了 WCF 路由服务;我还希望该服务(或类似的 WCF 服务)以规定的和统一的(与内容无关的)方式转换有效负载。例如,有效负载将始终采用 Foo 的形式。我想把它作为Bar在所有情况下。我很
我想使用 $locationProvider.html5Mode(true); 在 angularJs 中删除 # 哈希;但这导致所有 URL 都通过 angularJs 进行路由。我如何设置它以便只
我要听导航开始事件并判断其是否url属性是 /logout . 如果是这样,路由器应该停止触发连续事件,例如 路线已识别 , GuardsCheckStart , ChildActivationSta
有人可以解释我如何使用参数路由到 URL 吗? 例如id 喜欢点击产品并通过Id打开产品的更多信息。 我的路由到目前为止... angular.module('shop', ["cus
我目前正在 Angular: 7.2.14 上构建,想看看是否有人可以解释如何使用路由保护、共享服务或其他方式等重定向查询参数。 我试图解决的问题要求查询参数从根 Uri 路径传入,然后将路由重定向到
我是一名优秀的程序员,十分优秀!