内容简介:平常会有需要在文本款输入的时候限制字数,如果输入的时候,没有确认,还有字符处于高亮状态的话,此时如果直接取文本框的字符个数,得到的结果是包含高亮(即还没有确认的字符)的结果。 如下图示例:如果是nil的话,则表示该文本框没有高亮的区间,则说明文本框里的字符是已经确认的字符。此时计算的字符数就是准确的不带高亮的字符数。示例如下:
平常会有需要在文本款输入的时候限制字数,如果输入的时候,没有确认,还有字符处于高亮状态的话,此时如果直接取文本框的字符个数,得到的结果是包含高亮(即还没有确认的字符)的结果。 如下图示例:
UITextRange *textRange = [self.textField markedTextRange]; 该方法返回一个文本区间,来表示高亮的范围。
@property (nullable, nonatomic, readonly) UITextRange *markedTextRange; // Nil if no marked text.
如果是nil的话,则表示该文本框没有高亮的区间,则说明文本框里的字符是已经确认的字符。此时计算的字符数就是准确的不带高亮的字符数。
示例如下:
[[NSNotificationCenter defaultCenter]addObserver:self selector:@selector(textFieldDidChange:) name:UITextFieldTextDidChangeNotification object:nil];
//======================
- (void)textFieldDidChange:(NSNotification *)noti
{
UITextField *textField = (UITextField *)noti.object;
if ([textField isEqual:self.textField]) {
UITextRange *textRange = [self.textField markedTextRange];
if (!textRange) {//当为nil的时候来计算和截取输入的字符
if (self.textField.text.length > 10) {
self.textField.text = [self.textField.text substringToIndex:10];
}
}
}
}
复制代码
以上只是关于文本框输入的一个点儿,如有更好的方案,欢迎留言沟通。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网
猜你喜欢:本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
CSS3实用指南
吉伦瓦特 / 屈超、周志超 / 人民邮电出版社 / 2012-3 / 49.00元
CSS3为Web的视觉样式语言注入了强大的新功能,让设计人员更加轻松自如地设计优美而引人入胜的内容。借助CSS3,不使用图片就可以创建半透明背 景、渐变、阴影等夺人眼球的视觉效果;还可以使用漂亮、独特、非Web安全的字体显示文本;不用Flash就可以创建动画;不用JavaScript就可 以定制适应用户的设备和屏幕尺寸的设计。 本书通过一系列实用且新颖的范例,向读者展示如何实现以上功能和更多......一起来看看 《CSS3实用指南》 这本书的介绍吧!