swift组件化

swift组件化

看了很多关于iOS组件化的文章,觉得光是看不写不足以很好的理解组件化,所以就自己写了一个demo以组件化构建。

工程目录结构及组件介绍
1、工程目录

这个demo我采用的是carthage包管理工具。如若有不知道如何使用的Google一下就行,使用方法很简单,类似pod。以及如何将写好的framework提交到carthage管理,可以参考我的这篇笔记

屏幕快照 2018-07-10 13.55.19.png
屏幕快照 2018-07-10 13.44.57.png
2、组件介绍
zujianhuaDemo.png
  • JLRoutes是一个用于组件间跳转的第三方库。
  • ZQKit这是自定义的一个framework,是一些UIKit的扩展,但是此demo我只放一个UIImage的扩展。
  • ZQMediator自定义的组件中间协调者,具有一个单例。
  • ZQFirstComponent这是此demo抽离的第一个功能模块。
  • ZQSecondComponent这是此demo抽离的第二个功能模块。
demo视频:
2018-07-10 16_17_55.gif

视频中的home是第一模块,live是第二模块。

  • 从第一模块present一个橘黄色的控制器,并且这橘黄色控制器是在第二模块中创建的。
  • 从第二模块push一个蓝色的控制器,并且传递一个字符串,这蓝色的控制器是在第一模块中创建的,
Demo代码释义
1、AppDelegate.swift

在APPDelegate注册路由跳转scheme为ZQRouteOne,

func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplicationLaunchOptionsKey: Any]?) -> Bool {
    registerPushRouteWithScheme(scheme: "ZQRouteOne")
    registerPresentRouteWithScheme(scheme: "ZQRouteOne")
    return true
}

func application(_ app: UIApplication, open url: URL, options: [UIApplicationOpenURLOptionsKey : Any] = [:]) -> Bool {
    return JLRoutes(forScheme: "ZQRouteOne").routeURL(url)
}
2、AppDelegate+Extension

下面以注册push为例

/// 以push方式推出下一个页面
func registerPushRouteWithScheme(scheme: String) {
    JLRoutes(forScheme: scheme).addRoute("/push/:controller") {
        [weak self] (dic: [String: Any]) -> Bool in
        guard let clsString = dic["controller"] as? String else {
            debugPrint("not found controller string")
            return true
        }
        //在swift中clsString = AppProjectName.ClassName example:zujianhuaDemo.ViewController
        guard let cls = NSClassFromString(clsString) else {
            debugPrint("not found vc class: \(clsString)")
            return true
        }
        if cls is UIViewController.Type {
            let nextVC = (cls as! UIViewController.Type).init()
            self?.paramToVC(vc: nextVC, parameters: dic )
            
            let currentVC = self?.currentViewController()
            currentVC?.navigationController?.pushViewController(nextVC, animated: true)
        }
        return true
    }
}
3、第二模块SecondViewController

我们是在第二模块的控制器中push的第一模块的BlueViewController控制器页面,并且传值detail

@objc fileprivate func pushBtnClick() {
    guard let routeUrl = "ZQRouteOne://push/ZQFirstComponent.BlueViewController?detail=this detail text from other component".addingPercentEncoding(withAllowedCharacters: .urlQueryAllowed) else {return}
    guard let url = URL(string: routeUrl) else {
        return
    }
    UIApplication.shared.open(url, options: [:], completionHandler: nil)
}
4、主工程BaseTabBarViewController

由于mediatorFirstComponentMainVC()和mediatorSecondComponentMainVC()两个方法都是写在模块一和模块二ZQMediator的扩展中。

fileprivate func configChildViewControlelrs() {
    self.tabBar.tintColor = UIColor.orange
    if let firstVC = ZQMediator.default.mediatorFirstComponentMainVC() {
        addChildViewController(firstVC)
    }
    if let secondVC = ZQMediator.default.mediatorSecondComponentMainVC() {
        addChildViewController(secondVC)
    }
}
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

  • 1、通过CocoaPods安装项目名称项目信息 AFNetworking网络请求组件 FMDB本地数据库组件 SD...
    阳明AI阅读 16,128评论 3 119
  • 亲爱的小艳平: 今天你抹口红了!娇艳欲滴!同事们都很吃惊,你没有像以前一样害羞的不知所云,而是跟大伙儿大胆轻松的调...
    为爱分享阅读 240评论 0 3
  • 古城村后的土地沙质不适合种植庄稼作物,便被先人们开发了种了桑树。村人们从此也便以养蚕为生计了。 那些年,所有的土地...
    阳羊i阅读 267评论 1 2
  • 大盘和个股进入短期底部时候,在K线上通常就会呈现出一些规律性的特征: (1)长下影线的见底特征 长下影线的十字星或...
    老马分析阅读 491评论 0 0
  • 【猫宁15min写作】003/100 清晨写作已经坚持40天了,仍停留在流水账的模式中,但现在的流水账比以前做的有...
    滚来滚去的猫er阅读 281评论 0 0

友情链接更多精彩内容