前言
不管是WEB
还是Android
或者是iOS
开发中 我们都会有这样的问题
- 按钮点击时 连续点击只让第一次生效
- 搜索时文本不断变化导致调用多次接口
上面的两个问题解决后能大大提升用户体验 解决它们就用到了throttle
和debounce
WEB(JS)
Android(Java)
主要用到RxJava
和RxAndroid
iOS(OC/Swift)
MessageThrottle
- Swift可以用
RxSwift
如果项目中已经用到 或者想用
RxSwift
的话就选择第二种方式
如果项目不想引用太多东西 或者项目用的OC 就选择第一种方式
ReactiveCocoa
vsRxSwift
?RxSwift
虽然只支持iOS8之后的系统 但是现在基本只需适配iOS8以后了 所以不用担忧RxSwift
和RxJava
以及RxJS
语法基本都相似 这真的就是learn once, apply everywhere.
所以推荐使用RxSwift
MessageThrottle实例
在OC中使用
1 | - (void)viewDidLoad { |
如上例子中 设置的间隔为5秒 可设置的模式有三种
- rule.mode = MTPerformModeFirstly;
- rule.mode = MTPerformModeLast;
- rule.mode = MTPerformModeDebounce;
MTPerformModeFirstly
如果连续点击按钮 每5s的第一次生效MTPerformModeLast
如果连续点击按钮 每5s的最后一次生效MTPerformModeDebounce
如果连续点击按钮 则重置计时器 停止点击后5s操作生效
在Swift中使用
1 | self.usernameTextField.addTarget(self, action: #selector(updatePicImageView), for: UIControlEvents.editingChanged) |
这个和下面用RxSwift
的示例做了同样的事 可以对比一下
RxSwift实例
根据用户输入的名字变化 更新头像
1 | _ = self.usernameTextField.rx.text.orEmpty |