先自定义一个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. Redis使用总结(2):Python接口

    安装redis-py sudo pip2 install redis 牛刀小试 redis连接实例是线程安全的,可以直接将redis连接实例设置为一个全局变量直接使用.如果需要另一个Redis实例(o ...

  2. JavaScript基础—dom,事件

    Js基础-DOM 1:dom:文档对象模型 Dom就是html页面的模型,将每个标签都作为一个对象,js通过调用dom中的属性,方法就可以对网页中的文本框,层等元素进行编程控制.Dom就是一些让jav ...

  3. ASP.NET MVC程序播放H.264视频

    在这篇之前,Insus.NET不管是在ASP.NET还是ASP.NET MVC实现很多视频播放,你可以参考这篇链接:http://www.cnblogs.com/insus/category/4650 ...

  4. 基于ListBox的相关操作

    Winform中两个listbox的操作是平时比较常用的操作. 本次将以一个Winform实例来分享一下两个listbox的操作,包括:listbox添加项,项的上移下移等操作. 假设有两个listb ...

  5. js中局部变量必须用var去声明

    js中的变量与其他的脚本语言都是很不一样的,在function中你如果不用var 声明一个变量,那么这个变量将在全局可见,也就相当于创建了全局变量.所以在function中声明变量尽量都是用var来声 ...

  6. printf的题目

    以前学习于渊老师的<自己动手写操作系统>一书的时候,也自己实现过printf,不过那是比较简单的版本.最近看<程序员面试宝典>,做到这么一道题目:#include <st ...

  7. 孙鑫MFC学习笔记9:状态栏与工具栏编程

    1.在窗口创建之前就应该修改窗口的样式 2.单文档应用程序会把文档名作为应用程序标题,应该去掉FWS_ADDTOTITLE属性,然后修改lpszName为标题 3.在窗口创建完成后,可以通过SetWi ...

  8. 【转】php中XML、XSLT的结合运用

    原文:http://blog.csdn.net/bjbs_270/article/details/140253   下面我要讲的是一个简单的从数据库中抽取数据,生成XML文档,使用XSLT转换成HTM ...

  9. RecyclerView和PullToRefreshListView的对比

    项目中上拉刷新和下拉加载一直都是比较常见的:以前一般都是重写ListView或直接用PullToRefreshListView的框架:最近尝试用RecyclerView来实现下拉加载上拉刷新也是不错的 ...

  10. Scalaz(32)- Free :lift - Monad生产线

    在前面的讨论里我们提到自由数据结构就是产生某种类型的最简化结构,比如:free monoid, free monad, free category等等.我们也证明了List[A]是个free mono ...