我已经挖掘了stackoverflow并找到了我转换为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中执行此操作? 谢谢!
答案 0 :(得分:39)
更新2016/09/01:
我们可以使用NSTimers
或(自swift 2.0)NSObject的performSelector
和朋友。
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
)但是当您使用{{1}时目标 不 保留。这意味着,如果使用NSTimer
s,则必须确保定时器触发时目标(在这种情况下为NSTimer
)处于活动状态。否则会发生崩溃。
(顺便说一句:self
在内部使用performSelector
如果您对GCD计时器感兴趣,那么这个要点就是一个好的开始: maicki/TimerWithGCD.md