1,问题描述
有时我们开发的时候需要先把“确认”按钮初始设置为不可用,当文本框中输入文字以后,再将输入按钮变为可用。
2,实现原理
(1)要检测文本框内容的变化,我们需要让新界面的Controller遵循一个文本协议UITextFieldDelegate。
同时在viewDidLoad方法内将文本框的代理设置为MainListController当前实例。
然后实现textFile的shouldChangeCharactersInRange方法就能在文本框将要变化的时候执行一些代码。
(2)但这个只是将要变化时执行,而不是变化后。比如在这个方法内打印出文本框的内容,会发现每当我们改变文本框的内容时,打印出来的是上一次的内容。
比如先输入1,打印出来是空。再输入2,文本框上是12,但打印出来却是1.
要获取最新内容,则需要String的stringByReplacingCharactersInRange方法,但这个方法在Swift的String中又不支持。要解决这个问题,就要先替NSRange做个扩展。
3,代码如下
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
|
import UIKit
class ViewController : UIViewController , UITextFieldDelegate {
@IBOutlet weak var button: UIButton !
@IBOutlet weak var textField: UITextField !
override func viewDidLoad() {
super .viewDidLoad()
// Do any additional setup after loading the view, typically from a nib.
textField.delegate = self
}
func textField(textField: UITextField , shouldChangeCharactersInRange range: NSRange ,
replacementString string: String ) -> Bool {
let newText = textField.text
.stringByReplacingCharactersInRange(range.toRange(textField.text), withString: string)
button.enabled = countElements(newText) > 0
return true
}
override func didReceiveMemoryWarning() {
super .didReceiveMemoryWarning()
// Dispose of any resources that can be recreated.
}
} //扩展NSRange,让swift的string能使用stringByReplacingCharactersInRange extension NSRange {
func toRange(string: String ) -> Range < String . Index > {
let startIndex = advance (string.startIndex, self .location)
let endIndex = advance (startIndex, self .length)
return startIndex..<endIndex
}
} |