先自定义一个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限制中英文字数和光标定位以及第三方输入限制问题的更多相关文章

  1. Vim光标定位

    *定位到指定行n: 输入"nG". 或输入"ngg". 或输入":n" 这里,n就是指定的行的行号.注意,有时候G=gg. *跳到屏幕顶部: ...

  2. input长度随输入内容动态变化 input光标定位在最右侧

    <input type="text" onkeydown="this.onkeyup();" onkeyup="this.size=(this. ...

  3. input输入框的光标定位的问题

    input输入框的光标定位的问题 在给input输入框赋值的时候,或者在我之前写模拟下拉框js组件的时候,时不时会碰到光标的小bug问题,比如键盘中的 上移或者下移操作,在浏览器中光标会先移到最前端, ...

  4. js实现类似微信网页版在可编辑的div中粘贴内容时过滤剪贴板的内容,光标始终在粘贴内容后面,以及将光标定位到最后的方法

    过滤剪贴板内容以及定位可编辑div光标的方法: <!DOCTYPE html><html lang="en"><head>  <meta ...

  5. UITextView 光标定位

    在使用UITextView的时候, 如何在光标的位置插入字符 或者 图片? 以下Demo为你解答: 应用背景:键盘自定义emoji表情 #pragma mark - KVO - (void)obser ...

  6. UITextField/UITextView限制字数

    一,UITextFild限制字数(三步) 1,给textfild添加响应事件,类型为:UIControlEventEditingChanged [self.nickNameFild addTarget ...

  7. 可编辑div,将光标定位到文本之后

    类似qq回复一样,某人评论之后,在对评论进行回复之后,将光标定位到文本之后: function set_focus() { el=document.getElementById('guestbook_ ...

  8. JS控制光标定位,定位到文本的某个位置

    这是一个数字密码,要能够智能的跳转到文本的某个位置,就需要通过JS来控制跳转! 1.onkeyup监听 <input class="put" id="number- ...

  9. TextBox光标定位到文本末尾

    private void RichTextBox1_TextChanged(object sender, EventArgs e) { this.richTextBox1.Select(richTex ...

随机推荐

  1. 使用Qt installer framework制作安装包

    一.介绍 使用Qt库开发的应用程序,一般有两种发布方式:(1)静态编译发布.这种方式使得程序在编译的时候会将Qt核心库全部编译到一个可执行文件中.其优势是简单单一,所有的依赖库都集中在一起,其缺点也很 ...

  2. ASP.NET MVC系列:从Controller访问Model数据

    在项目解决方案中,添加一个MoviesController控制器,选择对应的模板,和模型类以及数据上下文:关于如何添加模型类和数据上下文,我们在ASP.NET MVC系列:添加模型中已经介绍过

  3. TCP 与 UDP

    TCP Transmission Control Protocol,传输控制协议,传输层通信协议. 采用“带重传的肯定确认”(Positive Acknowledge with Retransmiss ...

  4. lua编译出so文件

    把lua编译出so文件 http://superuser.com/questions/557884/getting-error-recompile-with-fpic http://guiquanz. ...

  5. Js 风骚的代码

    1.写自动调用的匿名函数 当我们写完一个函数立即调用时,总是 function a(){ } a(); 或许 var a = function(){ } a(); 而高手总是 (function(){ ...

  6. prototype和__proto__

    一.prototype和__proto__的概念 prototype是函数的一个属性(每个函数都有一个prototype属性),这个属性是一个指针,指向一个对象.它是显示修改对象的原型的属性. __p ...

  7. sql2012还原sql2008备份文件语句

    --sql2012还原sql2008语句 --选择master数据库,新建查询 输入下面sql语句 --选择兼容模式(sql 2008)创建数据库db RESTORE DATABASE db FROM ...

  8. 来自 Codrops 的7种创新的拖放交互界面

    Codrops 分享了一些界面拖放的交互设计想法.基本的思路是在拖动一个项目的时候,为特定的操作呈现出可投掷的区域.这节省了大量的界面空间 ,并给出了一个有趣的动态的互动.有很多应用场景,例如分类和组 ...

  9. Awesomplete - 零依赖的简单自动完成插件

    Awesomplete 是一款超轻量级的,可定制的,简单的自动完成插件,零依赖,使用现代化标准构建.你可以简单地添加 awesomplete 样式,让它自动处理(你仍然可以通过指定 HTML 属性配置 ...

  10. Sequence.js 实现带有视差滚动特效的图片滑块

    Sequence.js 功能齐全,除了能实现之前分享过的现代的图片滑动效果,还可以融合当前非常流行的视差滚动(Parallax Scrolling)效果.让多层背景以不同的速度移动,形成立体的运动效果 ...