检测用户何时停止/暂停输入 Swift
Detect when user stopped / paused typing in Swift
我研究了 Whosebug 并找到了我转换为 Swift 的解决方案,它似乎不起作用并且仍在执行选择器。
func searchBar(searchBar: UISearchBar, textDidChange searchText: String) {
self.filter.searchTerm = self.searchBar.text
NSObject.cancelPreviousPerformRequestsWithTarget(self, selector: "getHints", object: nil)
NSTimer.scheduledTimerWithTimeInterval(1, target: self, selector: "getHints", userInfo: nil, repeats: false)
}
swift有更好的方法吗?
谢谢!
更新 2016/09/01:
我们可以使用 NSTimers
或(自 swift 2.0 起)NSObject 的 performSelector
和朋友。
方法 1:performSelector
func textField(_ textField: UITextField, shouldChangeCharactersIn range: NSRange,
replacementString string: String) -> Bool {
NSObject.cancelPreviousPerformRequests(
withTarget: self,
selector: #selector(ViewController.getHintsFromTextField),
object: textField)
self.perform(
#selector(ViewController.getHintsFromTextField),
with: textField,
afterDelay: 0.5)
return true
}
func getHintsFromTextField(textField: UITextField) {
print("Hints for textField: \(textField)")
}
方法二:NSTimer
var timer: NSTimer? = nil
func textField(_ textField: UITextField, shouldChangeCharactersIn range: NSRange,
replacementString string: String) -> Bool {
timer?.invalidate()
timer = Timer.scheduledTimer(
timeInterval: 0.5,
target: self,
selector: #selector(ViewController.getHints),
userInfo: ["textField": textField],
repeats: false)
return true
}
func getHints(timer: Timer) {
var userInfo = timer.userInfo as! [String: UITextField]
print("Hints for textField: \(userInfo["textField"])")
}
注意我将 textField
传递给延迟函数。它并不总是必需的,但是当 textField
不容易访问或处理各种文本字段时,它可以让您的生活更轻松。
NSTimer
方法与 performSelector
有何不同?
当您调用 performSelector
时,目标 是 保留(在 swift 中,目标总是 self
) 但当您使用 NSTimer
时,目标 不会 保留。这意味着,如果您使用 NSTimer
s,您必须确保目标(在本例中为 self
)在计时器触发时处于活动状态。否则会发生崩溃。
(顺便说一句:performSelector
在内部使用 NSTimer
)
如果您对 GCD 计时器感兴趣,这个要点是一个很好的起点:
maicki/TimerWithGCD.md
我研究了 Whosebug 并找到了我转换为 Swift 的解决方案,它似乎不起作用并且仍在执行选择器。
func searchBar(searchBar: UISearchBar, textDidChange searchText: String) {
self.filter.searchTerm = self.searchBar.text
NSObject.cancelPreviousPerformRequestsWithTarget(self, selector: "getHints", object: nil)
NSTimer.scheduledTimerWithTimeInterval(1, target: self, selector: "getHints", userInfo: nil, repeats: false)
}
swift有更好的方法吗? 谢谢!
更新 2016/09/01:
我们可以使用 NSTimers
或(自 swift 2.0 起)NSObject 的 performSelector
和朋友。
方法 1:performSelector
func textField(_ textField: UITextField, shouldChangeCharactersIn range: NSRange,
replacementString string: String) -> Bool {
NSObject.cancelPreviousPerformRequests(
withTarget: self,
selector: #selector(ViewController.getHintsFromTextField),
object: textField)
self.perform(
#selector(ViewController.getHintsFromTextField),
with: textField,
afterDelay: 0.5)
return true
}
func getHintsFromTextField(textField: UITextField) {
print("Hints for textField: \(textField)")
}
方法二:NSTimer
var timer: NSTimer? = nil
func textField(_ textField: UITextField, shouldChangeCharactersIn range: NSRange,
replacementString string: String) -> Bool {
timer?.invalidate()
timer = Timer.scheduledTimer(
timeInterval: 0.5,
target: self,
selector: #selector(ViewController.getHints),
userInfo: ["textField": textField],
repeats: false)
return true
}
func getHints(timer: Timer) {
var userInfo = timer.userInfo as! [String: UITextField]
print("Hints for textField: \(userInfo["textField"])")
}
注意我将 textField
传递给延迟函数。它并不总是必需的,但是当 textField
不容易访问或处理各种文本字段时,它可以让您的生活更轻松。
NSTimer
方法与 performSelector
有何不同?
当您调用 performSelector
时,目标 是 保留(在 swift 中,目标总是 self
) 但当您使用 NSTimer
时,目标 不会 保留。这意味着,如果您使用 NSTimer
s,您必须确保目标(在本例中为 self
)在计时器触发时处于活动状态。否则会发生崩溃。
(顺便说一句:performSelector
在内部使用 NSTimer
)
如果您对 GCD 计时器感兴趣,这个要点是一个很好的起点: maicki/TimerWithGCD.md