如何假装优雅的限定UITextField的长度
2016年07月26日星期二
今天同事问我,怎么比较优雅的限制UITextField的长度,我一拍脑袋,这好办啊。鼓捣了半天,发现答案和好的解决方案不是拍脑袋就能解决的。在这里讲讲我当时的心路历程。
首先,我决定用分类来实现限制UITextField的长度,这点在后来解决了之后,发现是没问题的。轻车熟路,的在分类中添加了个属性。什么?分类不能添加属性?这怎么能难住一个码畜喃。talk is cheap,show me the code.
1 | @interface UITextField (MMTextLimteLong) |
1 | static NSString *longkey = @"textlong"; |
稍微讲解一下顺便把关联也给科普了吧:
要使用关联必须使用的头文件,关联暂时只用得到三个方法
1 | -(void)objc_setAssociatedObject(id object, void *key, id value, objc_AssociationPolicy policy); |
上面鼓捣一大堆,不知道有没有看懂,反正我是在实践中用了才懂了一些的。上面的方法貌似官方的叫法是associative,是和category一起作为objective-c的扩展机制的两个特性。category既类型,可以通过它来扩展方法;associative,可以通过它来可扩展属性,不过看大神貌似用这个可以动态的设定方法,当然也可以动态的设定属性。以后再来把玩。
回到正题,用上面的方法鼓捣一阵后,在分类中声明好了属性。然后我最开始的思路是,用KVO去监听UITextField的text的改变。事实证明,我还是too🐑too森破。鼓捣了几个小时后,网友告诉我,UITextField的text是监听不到的。我也不知道能不能监听到,反正KVO一直给我说:你说的啥?我听不见。然后我又误入了另外一个企图。说出来又是一把辛酸泪。我在分类中实现了UITextField的代理方法。然后事情就解决了。但是,事情往往没有你想的那么简单。我在分类中实现了自己的代理方法,如果别人在外部要用UITextField的代理方法,我内部实现的代理方法就不能用了啊。代理方法只能有一个~~~~也是专一的让我流泪。后来突然想到了UIControlEventEditingChanged。这才算是走上了正路。
我在-(void)setTextlong:(NSInteger)textlong;方法中加入了
1 | [self addTarget:self action:@selector(isChangelimite:) forControlEvents:UIControlEventEditingChanged]; |