GTMRouter
用Swift实现的视图控制器路由组件,简单易用!!!
直接下载代码,里面有Demo
Install Cocoapods if need be.
$ gem install cocoapods
Add GTMRouter
in your Podfile
.
use_frameworks!
pod 'GTMRouter'
Then, run the following command.
$ pod install
Copy GTMRouter
folder to your project. That's it.
Note: Make sure that all files in GTMRouter
included in Compile Sources in Build Phases.
This version requires Xcode 9.0 and Swift 4.
Firstly, import GTMRouter
.
import GTMRouter
// push方式打开
GTMRouter.push(url: "router://GTMRouterExample/ViewControllerB")
// present方式打开
GTMRouter.present(url: "router://GTMRouterExample/ViewControllerB")
GTMRouter.push(url: "router://GTMRouterExample/ViewControllerC?id=1&name=GTMYang&ctitle=bunengzhongwen")
let params:[String:Any] = ["image": UIImage(named: "logo.png") as Any]
GTMRouter.push(url: "router://GTMRouterExample/ViewControllerC?id=1&name=GTMYang&ctitle=bunengzhongwen", parameter: params)
/// Helper协议
public protocol GRHelper {
var navigationController: UINavigationController? {get}
var topViewController: UIViewController? {get}
}
有时候因为项目的个性化默认的Helper满足不了需求,这是可以自定义Helper类实现GRHelper协议 然后通过
/// 注入自己的Helper类
GTMRouter.setHelper(yourHelper)
因为苹果在Swift 4 中苹果修改了自动添加 @objc 的逻辑:一个继承 NSObject 的 swift 类不再默认给所有函数添加 @objc。只在实现 OC 接口和重写 OC 方法时才自动给函数添加 @objc 标识。
#缺点与不足 参数不支持一些类型:Optional, Optional, Optional, Optional 因为是使用的oc的setValue(val, forKey: key)方式来设置属性值的
如果您有好的改进方式,麻烦赐教
#参与开源 欢迎提交 issue 和 PR,大门永远向所有人敞开。
#开源协议 本项目遵循 MIT 协议开源,具体请查看根目录下的 LICENSE 文件。