前言
大家应该都知道,密码框有个常见的需求:用一个按钮切换密码的明文/密文显示。点一下显示明文,再点一下显示密文。
本来是个很简单的需求,因为 uitextfield 有securetextentry这个属性可以用。
发现问题
但没想到,简单的一句代码并不能解决问题:
1
2
3
|
- (ibaction)secureswitchaction:(id)sender {
self.passwordtextfield.securetextentry = !self.passwordinputtextfield.securetextentry;
}
|
问题在于,在切换明文/密文的时候,如果切换前后的字符串宽度不一样,字符串末尾到光标之间会出现一大段空白。
切换之后,光标前面有一段空白
官方文档里也没提这件事,估计又是官方实现的一个 bug 了。
解决方法
好在只需要简单加几句代码:
1
2
3
4
5
6
7
|
- (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];
就能解决这个问题,只是副作用是会让输入焦点切换到密码框。如果不介意的话,用这个方法也可以。
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流,谢谢大家对服务器之家的支持。
原文链接:http://www.jianshu.com/p/72271c023d6d