iOS 开发每天分享优质文章

开源 FastAction 事件处理库

2019-09-27  本文已影响0人  YxxxHao
FastActions.png

在日常开发之余,用 Swift 写了一个快速处理事件传递&处理的库 FastActions,简化事件的传递流程,提高编码效率。

FastActions 是一个用纯 Swift 来实现的快捷的事件处理库。在 MVC 架构模式开发,事件传递一件麻烦的事情,同层的 View 与 ViewController 通讯,通常使用 Delegate 来传递与处理事件,跨层访问则会用 Notification。这两种方式都比较繁琐,FastActions 的目的是取代 Delegate 与 Notification 来传递与处理事件。

Features

最简单的用例是 Button 点击时向所在的 ViewController 发送事件,只需要调用 button 的扩展方法发送事件,在 ViewController 实现 FastActionsMaps 协议的 fastActionsMaps 的方法,则可以获取到事件:

// View.swift
let params = FastActionsParams(tag: "kBntClickAction")
params.data = "Hi FastActions"
self.button.fa.addDispatchToVC(params: params, forControlEvents: .touchUpInside)
// or
// self.button.fa.addDispatchToVC("kBntClickAction", forControlEvents: .touchUpInside)

// ViewController.swift
extension ViewController: FastActionsMaps {
    func fastActionsMaps() -> Dictionary<String, Selector> {
        return [
                "kBntClickAction":#selector(clickBtn(_:)),
                ]
    }
    
    @objc func clickBtn(_ params: FastActionsParams) {
        print(params.data ?? "data is nil")
    }
}

使用 FastActions 向全局传递事件,响应者需要选择 subscribe 才能正常响应全局事件传递,在 deinit 时也需要 unsubscribe,FastActions 全局事件传递的内部是基于观察者模式实现的:

// View.swift
let params = FastActionsParams(tag: "kDispatchAllAction")
params.data = "Hi FastAction"
sender.fa.dispatch(params: params)

// ViewController.swift
class ViewController: UIViewController {
    deinit {
        self.fa.unsubscribe()
    }

    override func viewDidLoad() {
        super.viewDidLoad()
        self.fa.subscribe()
    }
}

extension NextViewController: FastActionsMaps {
    func fastActionsMaps() -> Dictionary<String, Selector> {
        return [
                "kDispatchAllAction":#selector(clickBtn(_:)),
                ]
    }
    
    @objc func clickBtn(_ params: FastActionsParams) {
        print(params.data ?? "data is nil")
    }
}

Requirements

Installation

CocoaPods

使用 CocoaPods 将 FastActions 集成到 Xcode 项目中,需要将 Podfile 中指定的 target 添加:

source 'https://github.com/CocoaPods/Specs.git'
platform :ios, '9.0'
use_frameworks!

target 'MyApp' do
  # other pod
  pod 'FastActions'
end

然后执行以下命令:

$ pod install

Carthage

使用 Carthage 将 FastActions 集成到 Xcode 项目中,需要在 Cartfile 中指定它:

github "dengyhgit/FastActions" ~> 1.0

然后,运行以下命令构建 FastActions framework:

$ carthage update FastActions --platform iOS
# Or `--platform macOS`, `--platform tvOS`

Other

Future of FastActions

FastActions 其目的主要是为事件传递提供更便捷的方式, 以提高我们的开发效率。FastActions 目前只提供了一些基本功能,它还有很大的改进空间,我们在后面会提供更多功能,让其变得更完善。当然,希望大家可以共同参与进来,共同努力。如果你在使用的时候遇到问题,也可以给我们提 Issues。

License

FastActions 是基于 MIT 协议下发布的,其详细信息,请参 LICENSE 文件。

上一篇 下一篇

猜你喜欢

热点阅读