JKChangeCapture swift 版本的捕捉属性变化的工具

  在OC的时代里,大家捕捉属性的变化通常是通过KVO机制来实现的,KVO把所有的属性变化都放在了一个方法进行相应处理,并不友好,之前基于KVO的机制实现了一套属性变化工具JKKVOHelper,这里不就在过多介绍这个了,在swift的时代里,KVO机制已经不能满足我们的需求,我这边基于协议写了一套属性变化的监听工具。

使用示例代码:

只需要在结构体,类,遵守协议即可
struct PublishSubjectViewModel:JKChangeCaptureProtocol {
    var publishObjectMap: [String : RxSwift.PublishSubject<JKPublistMessage>]?
发送属性变化:
var age:Int = 0 {
        didSet {
//          postMessage(key: "age", value: age) 如果不需要关注oldValue可以不传
            postMessage(key: "age", value: age, oldValue: oldValue)
        }
    }
    
    var num:Int = 0 {
        didSet {
            postMessage(key: "num", value: num, oldValue: oldValue)
        }
    }

处理属性变化:
  viewModel.observe(key: "age") { value in
            print("aaa \(value)")
        }.disposed(by: disposeBag)

   viewModel.observe(key: "age", of: Int.self) { value, oldValue in
            print("aaa \(value)")
            print("bbb \(oldValue)")
        }.disposed(by: disposeBag)
        
监听多个属性变化:
        viewModel.observe(keys: ["age","num"]) { message in
            print("aaa key: \(message?.key), value:\(message?.value), oldValue: \(message?.oldValue)")
        }.disposed(by: disposeBag)

RXSwift_47">基于RXSwift进行开发

  想必很多有接触过RXswift的同学看到disposeBag这个已经猜到了,这个工具是基于RxSwift进行开发的,主要目的是在捕捉到数据变化的同时能够进行一些装饰性的操作,在保证代码优雅的同时增加代码的扩展性。示例如下:

        viewModel.observe(key: "age", of: Int.self) { subject in
           return subject.skip(1)
        } detailBlock: { value, oldValue in

            print("aaa \(value)")
            print("bbb \(oldValue)")
        }.disposed(by: disposeBag)

大家可以在第一个block内部,对subject执行一些装饰性的操作,debouce,throttle,skip,map.等Rxswift支持的操作,具体看自己的业务需求。
pod集成

pod 'JKChangeCapture'

源码下载地址:https://github.com/xindizhiyin2014/JKKVOHelper.


http://www.niftyadmin.cn/n/5053225.html

相关文章

前端架构师之08_JavaScript对象

1 面向对象概述 1.1 面向过程与面向对象 面向过程&#xff1a;注重的是事情完成的具体的步骤&#xff0c;只有按照步骤一步一步的执行&#xff0c;才能够完成这件事情。 对于面向过程思想&#xff0c;我们扮演的是执行者&#xff0c;凡事都要靠自己完成。面向过程思想的劣势&…

Vue实现Hello World

<div id"aa"> <p>{{h}}</p> </div> <script src"https://cdn.jsdelivr.net/npm/vue2/dist/vue.js"></script> <script> const hello new Vue({ el:#aa, data:{ h : Hello World } }) </script>

大数据Flink(八十九):Temporal Join(快照 Join)

文章目录 Temporal Join(快照 Join) Temporal Join(快照 Join) Temporal Join 定义(支持 Batch\Streaming):Temporal Join 在离线的概念中其实是没有类似的 Join 概念的,但是离线中常常会维护一种表叫做 拉链快照表,使用一个明细表去 join 这个 拉链快照表 的 join …

PostgreSQL ON CONFLICT冲突时进行额外操作

前言 使用ON CONFLICT需设置键&#xff0c;否则报错“没有匹配ON CONFLICT说明的唯一或者排除约束”。 PostgreSQL的ON CONFLICT子句提供了多种冲突处理类型&#xff0c;用于在插入操作中处理冲突。以下是常见的几种类型&#xff1a; DO NOTHING&#xff1a;在发生冲突时不执…

redis部署与管理

目录 一、关系数据库与非关系型数据库&#xff1a; 1. 关系型数据库&#xff1a; 2.非关系型数据库&#xff1a; 二、关系型数据库和非关系型数据库区别&#xff1a; &#xff08;1&#xff09;数据存储方式不同&#xff1a; &#xff08;2&#xff09;扩展方式不同&#xf…

vue3+eleement plus日历选择季度

<template><div class"el-quarter-wrap"><el-popover width"280" v-model"visible"><template #reference><el-input v-model"quarterDate" placeholder"请选择季度" clearable :prefix-icon&qu…

HTML5+CSS3小实例:脉冲波纹催眠动画特效

实例:脉冲波纹催眠动画特效 技术栈:HTML+CSS 效果: 源码: 【html】 <!DOCTYPE html> <html><head><meta http-equiv="content-type" content="text/html; charset=utf-8"><meta name="viewport" content=&qu…

正点原子lwIP学习笔记——NTP实时时间实验

1. NTP简介 NTP&#xff08;Network Time Protocol&#xff09;网络时间协议基于UDP&#xff0c;用于网络时间同步的协议&#xff0c;使网 络中的计算机时钟同步到UTC&#xff0c;再配合各个时区的偏移调整就能实现精准同步对时功能。 NTP 服务器&#xff08;Network Time Pr…