UITextField限制中英文字数和光标定位以及第三方输入限制问题
先自定义一个UITextField的子类HLNavTextField,在控制器里调用子类的- (void)limitHansLength:(int)hans otherLength:(int)other方法来限制字数。
1、[UITextInputMode currentInputMode] -->不同输入法下返回的内容:
系统自带键盘:英文下返回en-US,中文下返回zh-Hans;
搜狗输入法:中英文下都返回zh-Hans;
百度输入法:中英文下都返回zh_CN;
GO输入法:中英文下都返回mul;
2、textField.textInputMode.primaryLanguage --> 不同输入法下返回的内容:
系统自带键盘:英文下返回en-US,中文下返回zh-Hans,emoji下返回nil;
搜狗输入法:中英文下都返回zh-Hans;
百度输入法:中英文下都返回zh_CN;
GO输入法:中英文下都返回mul;
#import <UIKit/UIKit.h> @interface HLNavTextField : UITextField
- (void)limitHansLength:(int)hans otherLength:(int)other; // hans:系统中文和emoji的限制数、第三方输入法中英文限制数;other:系统自带输入法英文输入状态的限制;
@end
从我自己的项目中抽出来的,没有经过单独测试。
#import "HLNavTextField.h" @interface HLNavTextField ()
@property (assign, nonatomic) int hans;
@property (assign, nonatomic) int other;
@end @implementation HLNavTextField // 用于更改Placeholder的文字大小、颜色、位置
- (void)drawPlaceholderInRect:(CGRect)rect {
NSAttributedString *placeholder = self.attributedPlaceholder;
NSRange range = NSMakeRange(, self.placeholder.length);
NSMutableDictionary *dict = [placeholder attributesAtIndex: effectiveRange:&range].mutableCopy;
dict[NSForegroundColorAttributeName] = [UIColor orangeColor];
dict[NSFontAttributeName] = [UIFont systemFontOfSize:];
CGRect myRect = CGRectMake(rect.origin.x + , rect.origin.y + , rect.size.width, rect.size.height);
[[self placeholder] drawInRect:myRect withAttributes:dict];
} // 注意区别初始化方式
- (instancetype)initWithCoder:(NSCoder *)coder
{
self = [super initWithCoder:coder];
if (self) {
self.hans = -;
self.other = -;
// 初始化时添加监听文字的改变
[self addTarget:self action:@selector(searchDidChange:) forControlEvents:UIControlEventEditingChanged];
}
return self;
} - (void)limitHansLength:(int)hans otherLength:(int)other {
self.hans = hans; // 设置中文状态下的限制字数
self.other = other; // 设置状态下的限制字数
} - (void)searchDidChange:(UITextField *)textField {
// 判断输入状态是否为英文
if (![textField.textInputMode.primaryLanguage isEqualToString:@"en-US"]) {
// 过滤掉输入时高亮状态下的情况
if (!textField.markedTextRange && (self.hans >= ) && (textField.text.length > self.hans)) {
[self setCaretPositionWithTextField:textField limit:self.hans];
}
} else {
// 英文输入状态下
if ((self.other >= ) && (textField.text.length > self.other)) {
[self setCaretPositionWithTextField:textField limit:self.other];
}
}
}
- (void)setCaretPositionWithTextField:(UITextField *)textField limit:(NSUInteger)length {
// 拿到截取之前的光标位置
UITextPosition *selectedPosition = textField.selectedTextRange.start;
// 截取限制字数以内的文本
textField.text = [textField.text substringToIndex:length];
// 恢复光标的位置
textField.selectedTextRange = [textField textRangeFromPosition:selectedPosition toPosition:selectedPosition];
} @end
支持插入文字、选中替换文字、联想输入文字,光标定位到新输入的文字后。
UITextField限制中英文字数和光标定位以及第三方输入限制问题的更多相关文章
- Vim光标定位
*定位到指定行n: 输入"nG". 或输入"ngg". 或输入":n" 这里,n就是指定的行的行号.注意,有时候G=gg. *跳到屏幕顶部: ...
- input长度随输入内容动态变化 input光标定位在最右侧
<input type="text" onkeydown="this.onkeyup();" onkeyup="this.size=(this. ...
- input输入框的光标定位的问题
input输入框的光标定位的问题 在给input输入框赋值的时候,或者在我之前写模拟下拉框js组件的时候,时不时会碰到光标的小bug问题,比如键盘中的 上移或者下移操作,在浏览器中光标会先移到最前端, ...
- js实现类似微信网页版在可编辑的div中粘贴内容时过滤剪贴板的内容,光标始终在粘贴内容后面,以及将光标定位到最后的方法
过滤剪贴板内容以及定位可编辑div光标的方法: <!DOCTYPE html><html lang="en"><head> <meta ...
- UITextView 光标定位
在使用UITextView的时候, 如何在光标的位置插入字符 或者 图片? 以下Demo为你解答: 应用背景:键盘自定义emoji表情 #pragma mark - KVO - (void)obser ...
- UITextField/UITextView限制字数
一,UITextFild限制字数(三步) 1,给textfild添加响应事件,类型为:UIControlEventEditingChanged [self.nickNameFild addTarget ...
- 可编辑div,将光标定位到文本之后
类似qq回复一样,某人评论之后,在对评论进行回复之后,将光标定位到文本之后: function set_focus() { el=document.getElementById('guestbook_ ...
- JS控制光标定位,定位到文本的某个位置
这是一个数字密码,要能够智能的跳转到文本的某个位置,就需要通过JS来控制跳转! 1.onkeyup监听 <input class="put" id="number- ...
- TextBox光标定位到文本末尾
private void RichTextBox1_TextChanged(object sender, EventArgs e) { this.richTextBox1.Select(richTex ...
随机推荐
- WCF Throttling 限流的三道闸口
WCF Throttling 限流的三道闸口 一.WCF Throttling 流量限制简介 我们期望WCF服务端能够处理尽可能多的并发请求,但是资源是有限的,服务不可能同时处理无限多的并发请求,如 ...
- 用Apache 里面的ab做一个简单的压力测试
我用的是xampp环境包. D:\xampp\apache\bin 进入这路径, 找到ab.exe 尝试双击打开ab.exe 但不能如愿, 这两个都是一个压力的测试软件, 是apache自带的; 好 ...
- 《Java4Android》视频学习笔记——抽象类和抽象函数
抽象函数的语法特征 1.类是抽象的,对象是具体的.面向对象里面有个非常重要的特征:先抽象,后具体. 2.只有函数的定义,而没有函数体的函数叫做抽象函数. abstract void fun(); ( ...
- python 学习笔记5(深浅拷贝与集合)
拷贝 我们已经详细了解了变量赋值的过程.对于复杂的数据结构来说,赋值就等于完全共享了资源,一个值的改变会完全被另一个值共享. 然而有的时候,我们偏偏需要将一份数据的原始内容保留一份,再去处理数据,这个 ...
- Android 亮度调节
最近在做一个App的设置项,亮度调节.真正做时,发现Android亮度调节比预想要复杂一些.其实目前网上已有不少这方面的资料,但有些博文具有一定误导性.在此将这块内容按照自己理解整理一下. 整体上看, ...
- spring mvc+ELK从头开始搭建日志平台
最近由于之前协助前公司做了点力所能及的事情,居然收到了一份贵重的端午礼物,是给我女儿的一个乐高积木,整个有7大包物件,我花了接近一天的时间一砖一瓦的组织起来,虽然很辛苦但是能够从过程中体验到乐趣.这次 ...
- (原) 1.2 Zookeeper伪集群安装
本文为原创文章,转载请注明出处,谢谢 Zookeeper伪集群安装 zookeeper单机安装配置可以查看 1.1 zookeeper单机安装 1.复制三份zookeeper,分别为zookeeper ...
- C#如何实现一个简单的流程图设计器
以前看过不少Window Form开发的流程图设计器,支持节点拖放,非常方便即可设计出很美观的流程图,作为一个程序员,对其内部实现原理一直很好奇,感叹有朝一日自己如果可以开发一款类似的软件那是多么让人 ...
- Snabbt.js – 极简的 JavaScript 动画库
Snabbt.js 是一个简约的 JavaScript 动画库.它会平移,旋转,缩放,倾斜和调整你的元素.通过矩阵乘法运算,变换等可以任何你想要的方式进行组合.最终的结果通过 CSS3 变换矩阵设置. ...
- 值得 Web 开发人员收藏的16款 HTML5 工具
HTML5 正在迅速改变创建和管理网站的方式.HTML5 在不同的领域让网页设计更强大的.快速,安全,响应式,互动和美丽,这些优点吸引更多的 Web 开发人员使用 HTML5 开发各种网站和应用程序. ...