先来看看要实现的效果图
一.介绍一下功能
当输入一个邮箱的数字,会默认在后面匹配出来@qq.com,当然这个默认@qq.com可以换成其他的如@163.com等等。这里默认是@qq.com,因为我们的产品汪做过统计大多数用户还是用的qq邮箱,所以默认是@qq.com。
当输入@符号还是不会有所变化,但是如果在@之后再输入字符,会将这个字符和你想要提示的邮箱后缀做匹配,我这里是需要匹配@qq.com,@163.com,@126.com,@yahoo.com,@139.com,@henu.com类型。例如:在@之后你输入了1,这个时候会在@1之后匹配出来63.com。接着,当你在@1之后又输入了2,会在@12后面匹配出来6.com。这些匹配的优先级是根据你给的需要匹配邮箱类型的顺序来的,并且这些想要匹配的邮箱类型也是完全可配的,可根据产品的需求作自己的定制。
二.说一下用法
1.先说一下如果你是在xib中想实现这个功能,首先要拖拽一个textfield,设置好约束,然后让这个textfield的类关联到xltextfield,当前前提你要下载并导入了xltextfield.h
和xltextfield.m
,切记不要忘了将textfield.delegate
设置给viewcontroller,textfield样式可在xib自行设置,匹配的邮箱区域颜色可自行设置,然后在代码中只需要调api
1
2
3
4
5
6
|
/**
*
*1.通过xib创建只需要赋值此参数即可
*@param mailtypearray邮箱匹配类型
*
*/ @property(nonatomic,strong)nsmutablearray*mailtypearray;
|
示例代码:
1
|
self.textfield.mailtypearray= [nsmutablearrayarraywithobjects:@ "@qq.com" ,@ "@163.com" ,@ "@126.com" ,@ "@yahoo.com" ,@ "@139.com" ,@ "@henu.com" ,nil];
|
xltextfield.h还提供了一个可选的mailmatchcolor
属性这个属性是uicolor类型的,是匹配邮箱类型的颜色,可根据需求自行设置。
1
2
3
|
/**
*optional匹配的邮箱类型后缀默认是rgb为170 170 170的颜色,可自行设置
*/ @property(nonatomic,strong)uicolor* mailmatchcolor;
|
2.通过手动frame创建两个基本参数设置大小和字号,其他设置可额外自行设置,调用api
1
2
3
4
5
6
7
8
|
/**
*2.通过手写创建textfield时候调用
*
*@param frameframe大小
*@param fontsize textfield大小
*
*@return self
*/ - (instancetype)initwithframe:(cgrect)frame fontsize:(cgfloat)fontsize;
|
示例代码:
1
2
3
4
5
|
xltextfield * field = [[xltextfield alloc] initwithframe:cgrectmake(100, 200, 200, 30) fontsize:12];
field.placeholder = @ "输入邮箱地址" ;
field.mailtypearray = [nsmutablearray arraywithobjects:@ "@qq.com" ,@ "@163.com" ,@ "@126.com" ,@ "@yahoo.com" ,@ "@139.com" ,@ "@henu.com" , nil];
field.mailmatchcolor = [uicolor redcolor]; 可选属性
[self.view addsubview:field];
|
我在示例程序中只针对xib的textfield写了手势关闭,结束textfield的输入操作,手洞创建textfield没有写结束第一响应者的操作。如果你在实际使用中,可以根据你的需求例如点击键盘的完成按钮,或者触摸屏幕的view等场景下结束textfield的键盘第一响应者,从而取textfield的text进行额外的需求操作。
可根据自己需求定制自己的frame,font大小。不过不支持init
和new
初始化方法,即使用了也没关系,会有一个温馨的报错提示
1
|
- (instancetype)init__attribute__((unavailable( "init方法不可用,请用initwithname:fontszie:" )));+ (instancetype)new__attribute__((unavailable( "init方法不可用,请用initwithname:fontszie:" )));
|
三.介绍一下实现原理
1.可能你不看源码,就认为是一个textfield实现了全部功能,其实no.我这里是配合了一个label,在xib实现时利用aulayout手动添加label。textfield只是用来让用户输入,label用来存储匹配之后的邮箱(邮箱号码+邮箱类型),并且展示。你看到的其实是label的text内容。当最后结束编辑的时候,label会将内容复制给textfield的text,然后清空label。label只是在这里提一下实现方式,真正使用的值还是通过textfield.text
拿到的值。在这里你可能会吐槽,为什么不用一个textfield呢,多简单省事。但是事实是我尝试过一个textfield,中间遇到了一个坑,好像是textfield一个bug,暂且这样说 因为当时确实是很奇葩的问题,具体是那么也忘记了,这里也不展开说了,有兴趣你可以用一个textfield来尝试一下哈。
2.textfield的代理方法全部封装在textfield.m
内部,在内部已经处理了这些代理,更加方便他人调用,不用再花很多心思在调试textfield的代理方法上。不论是用xib还是用手动代码创建,都不需要设置textfield.delegate
给控制器。
3.在textfield的shouldchangecharactersinrange
代理方法中针对你输入的每一个字符进行邮箱的匹配,下面会有这一块的完整代码。在textfielddidendediting
代理方法中将label的值赋值给textfield.text
,然后将label.text
清空,直接取textfield.text
作为我们最终的结果。
下面贴上匹配邮箱过程的关键代码,并且每行都有注释。
1
2
3
4
5
6
7
8
9
10
11
12
|
/**
*匹配邮箱过程
*
*@param rangerange
*@param string用户输入string
*/ - ( void )configmailmatchingrange:(nsrange)range replacementstring:(nsstring*)string
{ //获取完整的输入文本nsstring*completestr = [self.textstringbyreplacingcharactersinrange:rangewithstring:string];//以@符号分割文本nsarray*temailarray = [completestrcomponentsseparatedbystring:@"@"];//获取邮箱前缀nsstring*emailstring = [temailarrayfirstobject];//邮箱匹配没有输入@符号时用@匹配nsstring*matchstring =@"@";if(temailarray.count>1){//如果已经输入@符号截取@符号以后的字符串作为匹配字符串matchstring = [completestrsubstringfromindex:emailstring.length];
} //匹配邮箱得到所有跟当前输入匹配的邮箱后缀nsmutablearray*suffixarray = [selfcheckemailstr:matchstring];//边界控制如果没有跟当前输入匹配的后缀置为@""nsstring*fixstr = suffixarray.count>0? [suffixarrayfirstobject] :@"";//将lblemail部分字段隐藏nsintegercutlenth = suffixarray.count>0? completestr.length: emailstring.length;//最终的邮箱地址self.email= fixstr.length>0? [nsstringstringwithformat:@"%@%@",emailstring,fixstr] : completestr;//设置lblemail的attributensmutableattributedstring*attributestring = [[nsmutableattributedstringalloc]initwithstring:[nsstringstringwithformat:@"%@%@",emailstring,fixstr]];
[attributestringaddattribute:nsforegroundcolorattributenamevalue:[uicolorclearcolor]range:nsmakerange(0,cutlenth)];self.maillabel.attributedtext= attributestring; //清空文本框内容时隐藏lblemailif(completestr.length==0){self.maillabel.text=@"";self.email=@"";
}
}
|
四、总结
以上就是ios实现邮箱模糊匹配功能的全部功能,实现后是不是很好用呢?感兴趣的快快动手实践起来,希望对大家的学习或者工作能有所帮助。