密码框有个常见的需求:用一个按钮切换密码的明文/密文显示。点一下显示明文,再点一下显示密文。
本来是个很简单的需求,因为 UITextField 有secureTextEntry
这个属性可以用。但没想到,简单的一句代码并不能解决问题:
- (IBAction)secureSwitchAction:(id)sender {
self.passwordTextField.secureTextEntry = !self.passwordInputTextField.secureTextEntry;
}
问题在于,在切换明文/密文的时候,如果切换前后的字符串宽度不一样,字符串末尾到光标之间会出现一大段空白。
切换之后,光标前面有一段空白官方文档里也没提这件事,估计又是官方实现的一个 bug 了。好在只需要简单加几句代码:
- (IBAction)secureSwitchAction:(id)sender {
self.passwordTextField.secureTextEntry = !self.passwordTextField.secureTextEntry;
NSString* text = self.passwordTextField.text;
self.passwordTextField.text = @" ";
self.passwordTextField.text = text;
}
就能解决问题了。
p.s. 我当时还查到了这篇文章 只用一行代码[self.passwordInputTextField becomeFirstResponder];
就能解决这个问题,只是副作用是会让输入焦点切换到密码框。如果不介意的话,用这个方法也可以。
网友评论
但是解决这个问题很简单,你只需要加一个判断就行了 if ([_textField isFirstResponder]) { //becomeFirstResponder }
这样就完美解决这个问题了,而且显得更优雅一些
: )
textField.font = nil;
textField.font = [UIFont systemFontOfSize:15];
虽然怪怪的, 但是很好用.! 可以省去上面那一步了..