Skip to content

zgjff/FJRouter

Repository files navigation

FJRouter

安装

Swift Package Manager

使用 Swift PM 的最简单的方式是找到 Project Setting -> Swift Packages 并将 FJRouter 添加在其中。 搜索 https://github.com/zgjff/FJRouter

CocoaPods

在你的 Podfile 文件中添加 FJRouter:

pod 'FJRouter'

然后运行 pod install

用法

注册路由

1: 关于路由结构FJRoute

路由的名称name: 建议注册路由的时候给路由设置名称, 原因有两点:

1: 当路由路径比较复杂,且含有参数的时候, 如果通过硬编码的方法直接手写路径, 可能会造成拼写错误,参数位置错误等

2: 在实际app中, 路由的URL格式可能会随着时间而改变, 但是一般路由名称不会去更改

设置路由的名称之后, 后续的跳转均可以通过name进行。

路由路径path: 路由路径的解析通过正则进行解析, 支持路径参数设置。eg:

路径/family/:fid, 可以匹配以/family/...开始的url, eg: /family/123, /family/456 and etc.

路径/user/:id/book/:bookId, 可以解析出参数分别需要id, bookId, 可以匹配/user/../book/...的url, eg: /user/123/book/456 and etc.

路由builder: 用于构建路由的指向控制器。此类型是个构建对应控制器的枚举类型: 包含只创建的default和自动创建并处理显示的display

FJRoute(path: "/", name: "root", builder: { sourceController, state in
    UINavigationController(rootViewController: ViewController())
})

路由animator: 用于显示路由指向控制器的转场动画。

只适用与适用go、goNamed进行跳转的方式, 使用push、pushNamed、present、presentNamed时,此参数无任何意义。

框架内部已经内置了多种实现. FJRoute.XXXXAnimator

路由拦截器redirect: 这是一个路由拦截器协议, 具体要求如下:

/// 指向需要重定向的路由。
///
/// 可以携带参数.eg, 目标路由是`/family/:fid`, 则需要完整传入`fid`, 即`/family/123`
func redirectRoute(state: FJRouterState) async throws -> String?

框架已经提供了一个通用的拦截器实现FJRouteCommonRedirector

关联的子路由routes: 可以见同一个模块下的路由, 放在一起注册。

注意: 强烈建议子路由的path不要以/为开头

let route = try! FJRoute(path: "settings", builder: ..., routes: [
    try! FJRoute(path: "user", builder: ...),
    try! FJRoute(path: "pwd", builder: ...),
    try! FJRoute(path: "info/:id", builder: ...),
])

2: 注册

通过构建路由FJRoute对象进行注册:

FJRouter.shared.registerRoute(route: FJRoute)

直接通过路由path进行注册:

FJRouter.shared.registerRoute(path: String, ...)

设置路由

设置允许最大重定向的次数, 若是匹配的路由重定向次数超过设置值, 则会匹配失败.

FJRouter.shared.setRedirectLimit(50)

设置路由匹配失败时的显示页面, 框架内部默认使用的错误页面UI较简陋, 可以通过此方法调整设置

FJRouter.shared.setErrorBuilder { state in
    return UIViewController()
}

跳转

强烈建议跳转的时候使用以goNamed为前缀的方法进行跳转

1: 当路由路径比较复杂,且含有参数的时候, 如果通过硬编码的方法直接手写路径, 可能会造成拼写错误,参数位置错误等

2: 在实际app中, 路由的URL格式可能会随着时间而改变, 但是一般路由名称不会去更改

FJRouter.shared.goNamed("login")
FJRouter.shared.go("/login")

go到匹配路由页面: 框架内部处理跳转到匹配路由页面的方式

会优先调用路由的animator参数; 若是animatornil, 框架内部会先尝试push, 然后尝试present

FJRouter.shared.go(location: "/login")
FJRouter.shared.goNamed("user", params: ["id": "123"])

跳转方式

1: 系统push

注册路由的时候animator设置为SystemPushAnimator

2: 系统present

注册路由的时候animator设置为SystemPresentAnimator

3: 设置app window的rootController

注册路由的时候animator设置为AppRootControllerAnimator

4: 使用自定义弹窗转场动画

注册路由的时候animator设置为CustomPresentationAnimator

5: 系统push/pop动画风格的present转场动画, 支持侧滑dismiss

注册路由的时候animator设置为SystemPushPopTransitionAnimator

5: 其它跳转动画

准守并实现FJRouteAnimator路由动画协议, 然后在注册路由的时候设置animator

About

No description or website provided.

Topics

Resources

License

Stars

Watchers

Forks

Packages

No packages published