UITextFiled自动补全输入,选中补全内容。NSRange和UITextRange的相互转换。-b
有个需求就是 需要用户输入几位以后账号,可以根据本地存储的登录成功的账号,进行自动补全,并且补全内容为选中状态,不影响用户的新输入。
研究了一下,下面是完整的实现的方法。
补充个下载地址http://download.csdn.net/detail/darkmengqi/8426463
写在 textFiled的delegate里面,这样当有输入时会调用此方法。
- -(BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string{
- if ([string isEqualToString:@""]) {//删除的话
- return YES;
- }
- NSMutableString *text = [[NSMutableString alloc]initWithCapacity:0];
- [text appendString:textField.text];
- [text deleteCharactersInRange:range];//在选中的位置 插入string
- [text insertString:string atIndex:range.location];
- if (text.length>2) { // 限制从2个以上才开始匹配 根据需求 自己设定
- NSString *behind = [self matchString:text]; //匹配是否有开头相同的
- if (behind) {
- [text appendString:behind];
- textField.text = text;
- UITextPosition *endDocument = textField.endOfDocument;//获取 text的 尾部的 TextPositext
- // 选取尾部补全的String
- UITextPosition *end = [textField positionFromPosition:endDocument offset:0];
- UITextPosition *start = [textField positionFromPosition:end offset:-behind.length];//左-右+
- textField.selectedTextRange = [textField textRangeFromPosition:start toPosition:end];
- return NO;
- }else{
- return YES;
- }
- }
- return YES;
- }
顺便粘贴下 匹配字符的 代码,很简单。
- -(NSString *)matchString:(NSString *)head{
- for (int i = 0; i<[_array count]; i++) {
- NSString *string = _array[i];
- if ([string hasPrefix:head]) {
- return [string substringFromIndex:head.length];
- }
- }
- return nil;
- }
这样就实现了一开始说的那个需求。
下面再说一下 光标的 一些问题。
获取光标的位置
UITextRange *selectedRange = [textField selectedTextRange];
根据NSRange 转换成 NSTextRange
- UITextPosition *beginning = textView.beginningOfDocument;
- UITextPosition *start = [textView positionFromPosition:beginning offset:range.location];
- UITextPosition *end = [textView positionFromPosition:start offset:range.length];
- nbsp;UITextRange *textRange = [textView textRangeFromPosition:start toPosition:end]];
根据NSTextRange转换成 NSRange
- - (NSRange) selectedRange:(UITextField *)textField
- {
- UITextPosition* beginning = textField.beginningOfDocument;
- UITextRange* selectedRange = textField.selectedTextRange;
- UITextPosition* selectionStart = selectedRange.start;
- UITextPosition* selectionEnd = selectedRange.end;
- const NSInteger location = [textField offsetFromPosition:beginning toPosition:selectionStart];
- const NSInteger length = [textField offsetFromPosition:selectionStart toPosition:selectionEnd];
- }
UITextFiled自动补全输入,选中补全内容。NSRange和UITextRange的相互转换。-b的更多相关文章
- 2016/3/31 ①全选时 下面选项全选中 ② 下面不选中时 全选取消 ③在“” 中 转义字符的使用\ onclick=\"Checkpa(this,'flall')\"; ④区别于分别实现 重点在于两种情况合并实现
testxuanbuxuan.php <!DOCTYPE html> <html lang="en"> <head> <meta char ...
- RubyMine中自动完成只输入部分字母
RubyMine中自动完成只输入部分字母 1,有下划线情况(其实看第二点跟下划线就关系不大了) 对于attr_reader之类的输入,输入attr之后,下划线可以不输入,然后输入r或者e都可以出来, ...
- bootstrap实现checkbox全选、取消全选
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <!-- 最新版本的 ...
- js全选与取消全选
实现全选与取消全选的效果 要求1(将军影响士兵):点击全选按钮,下面的复选框全部选中,取消全选按钮,下面的复选框全部取消 思路:复选框是否被选中,取决于check属性,将全选按钮的check属性值赋值 ...
- Jquery实现checkbox全选、取消全选和反选
最近在看廖雪峰的Jquery教程,事件篇的练习题比较综合,研究了很久终于研究出来了,现在分享出来,提供给小白学习.题目如下: 首先要获取到全选checkbox和每一项的checkbox,然后通过逻辑代 ...
- vue+el-table在ajax分页时支持全选单页和全选所有
需求:el-table中,ajax分页的情况下,要支持全选单页和全选所有页中的记录,效果如下图所示: 界面代码: <el-table :data="tableDat ...
- Silverlight 中DataGrid中全选与非全选问题
问题:当点击全选时,全选所有的复选框,但是滚动屏幕时,却复选框就会取消选中 一.解决方法(将要展示的实体数据模型添加bool属性,在数据绑定时添加click时间,盘带选中的状态,就可以了) 1. xa ...
- jQuery --checkbox全选和取消全选简洁高效的解决办法
最近在公司做了一个小项目,其中有一个全选和取消全选的这么一个模块,搞了半天找不到一种最佳的解决方案!后来通过各种努力找到了一种简洁高效的解决办法,这里想和大家分享一下.有问题的话,还望各路大神指导一二 ...
- bootgrid修改成可以全勾选和全取消勾选操作
1. 引言 由于项目需要,需要在不同页面上选择全勾选能全部勾选所有的记录,反勾选也如此.这个需求可以解决了一个样例:如果有150条记录,当前页就10条,你又在每一个页面勾选部分的记录,然后,如果你要全 ...
随机推荐
- hdu 4602 Partition 数学(组合-隔板法)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4602 我们可以特判出n<= k的情况. 对于1<= k<n,我们可以等效为n个点排成 ...
- [转载]Linux服务器性能评估与优化
转载自:Linux服务器性能评估与优化 一.影响Linux服务器性能的因素 1. 操作系统级 CPU 内存 磁盘I/O带宽 网络I/O带宽 2. 程序应用级 二.系统性能评估标准 影响性 ...
- I - Fire Game
题目大意: 火焰游戏 在一个];][] = { {,},{,},{-,},{,-} };; i<M; i++) ; j<N; j++) { ) ...
- poj1017
一个工厂制造的产品形状都是长方体,它们的高度都是h,长和宽都相等,一共有六个型号,他们的长宽分别为1*1, 2*2, 3*3, 4*4, 5*5, 6*6.这些产品通常使用一个 6*6*h 的长方体包 ...
- keil中for循环变量递减,无法跳出循环的问题
定义j时应注意其变量类型char,此循环当j=0时,再执行一次则keil中j=0XFF,而不是-1,所以无法跳出循环.但在vc6.0中是可以跳出循环的. 解决办法如下:不能让j的值为负数 uchar ...
- slidingmenu+fragment实现经常使用的側滑效果(包含Fragment状态的保存)
一.需求 关于fragment的问题,一直想写一篇博客了.应该当初自己也是对这玩意一点都不熟悉到如今也大概知道个日常的使用的地步. 一个側滑的导航栏,内有4个条目.每个选项点击进入相应的界面,每个界面 ...
- [Angualr 2] Watch for changes
You can watch for form / control changes by using .valueChanges.observe({...}): this.sku.valueChange ...
- 今日推荐(三)AndroidResideMenu类似QQ侧滑效果
效果图: DEMO 本代码即是DEMO,您可以下载后选择您喜欢的IDE运行.SDK版本建议使用4.0以上 Version Migration 从 v1.0, v1.1, v1.2, v1.3 升级到 ...
- 从零开始,在windows上用nodejs搭建一个静态文件服务器
从零开始,在windows上用nodejs搭建一个静态文件服务器 首先安装nodejs: 新建一个node文件夹 下载node.exe到该文件夹 下载npm然后解压到该文件夹 现在node文件夹是这样 ...
- 使用Maven构建javaWeb项目时,启动tomcat出错:严重: Error configuring application listener of class org.springframework.web.context.ContextLoaderListener java.lang.ClassNotFoundException: org.springframework.web.conte
在初学使用maven构建javaWeb的项目的时候,启动tomcat加载时,总是提示如下错误,辛苦一番终于找到解决办法. 严重: Error configuring application liste ...