textField格式化输入Demon资源下载
UItextfiled的自定义封装,功能包括
1.输入格式化(银行卡号 电话号码 格式)
2.可以将输入存为输入记录,输入时更具输入内容去动态赛选输入记录
3.键盘监听和frame改变
4.下拉列表效果如下:
大概的思路很简单 就是 将一个 UItextfiled 放到一个 view上面 让后每次都调用这个view 就好
用到的知识点包括
1.UItextfiled的基本用法
2.通知
3.谓词搜索
4.响应链
5.get set 方法
6.简单的逻辑算法ZJTextfieldView包括五种模式
typedef NS_ENUM(NSInteger, ZJTextFieldStyle) {
ZJTextfieldStyleNone,//默认的textfiled 和普通的用法一样,没有下拉框和记录
ZJTextfieldStyleBank,//银行卡模式 四位一个间隔空格 16位 或者19位,有下拉框和记录
ZJTextfieldStylePhone,//手机号格式 *** **** ****,有下拉框和记录
ZJTextfieldStyleTableList,//根据数据展现数据表
ZJTextFieldStyleAccount//普通的输入格式,有下拉框和记录
};
该类暴漏出来的方法和属性
@interface ZJTextfieldView : UIView
//textfiled 输入的格式化格式 有四种
@property (nonatomic) ZJTextFieldStyle ZJTextfieldStyle;//控件里面包含的系统的 textfiled
@property (nonatomic,strong)UITextField * ZJtextfield;//读取空间的是显示数据
@property (nonatomic,copy)NSString * ZJtext;//本地数据希腊框数据 ZJTextfieldStyleTableList格式是的数据
@property (nonatomic,strong)NSMutableArray * talbeListArray;
//代码初始化的方法
- (instancetype)initWithFrame:(CGRect)frame;//- (instancetype)initWithCoder:(NSCoder *)aDecoder;
//输入框内容改变时调用这个方法 并且去处理格式化算法bank 和 phone
- (BOOL)ZJtextField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string;
//获取输入框的数据 将字符串中的空格 删除
- (NSString *)ZJtextFiledViewText:(NSString*)string;
//开始编辑是创建下拉框
- (void)ZJtextFieldCreateTableviewDidBeginEditing:(UITextField *)textField;
//将输入框内如本地持久化 存入plist
- (void)ZJtextFieldWriteTextDidEndEditing:(UITextField *)textField;
//return取消键盘第一响应
- (BOOL)ZJtextFieldShouldReturn:(UITextField *)textField;
首先 介绍该类的使用方法
//当然前提是引入头文件
- (void)viewDidLoad {
[super viewDidLoad];
ZJTextfieldView * tfv = [[ZJTextfieldView alloc]initWithFrame:CGRectMake(50, 50, 300, 50)];
//初始化frame tfv.ZJtextfield.borderStyle = UITextBorderStyleRoundedRect;
//tfv 是创建出来的实例对象 其有一个属性就是ZJtextfield ,他其实就是一个UItextfield 所以我们可以通过它来设置textfield的一些基本属性
tfv.ZJTextfieldStyle = ZJTextfieldStyleBank;
//选择模式为银行卡格式
tfv.ZJtextfield.placeholder = @"银 行 ZJTextfieldStyleBank";
tfv.ZJtextfield.delegate = self;
//同样应为控件里面包含了UItextfield 所以还要准守七代理方法
[self.view addSubview:tfv];
self.zjtext = tfv;
//self.zjtext 为一个全局的变量
}
当然写到这里还没有完我们还需实现UItextfiled的四个代理方法 而且必须实现当然过程很简单
- (void)textFieldDidBeginEditing:(UITextField *)textField{
//开始编辑是创建下拉框
if (textField == self.zjtext.ZJtextfield) {
[self.zjtext ZJtextFieldCreateTableviewDidBeginEditing:textField];
}
}
- (void)textFieldDidEndEditing:(UITextField *)textField{
//输入完成时 将数据本地持久话
if (textField == self.zjtext.ZJtextfield) {
[self.zjtext ZJtextFieldWriteTextDidEndEditing:self.zjtext.ZJtextfield];
}
}
- (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string{
//正在输入时 会调用算法 对齐进行格式化
if (textField == self.zjtext.ZJtextfield) {
return [self.zjtext ZJtextField:textField shouldChangeCharactersInRange:range replacementString:string];
}
return YES;
}
- (BOOL)textFieldShouldReturn:(UITextField *)textField{
//取消键盘第一相应
if (textField == self.zjtext.ZJtextfield) {
return [self.zjtext ZJtextFieldShouldReturn:textField];
}
return YES;
}
好的到这里他的用法已经结束了 就是这么简单 上面描述的功能全部就实现了,如果需要多个textfiled 那么只需要在四个代理方法里面 else if(text == 对象名字){调用各自代理点额方法就好}
接下来我们来说一下原理
//初始化
- (instancetype)initWithFrame:(CGRect)frame{
if (self = [super initWithFrame:frame]) {
[self addViewTextfiled:frame];
self.backgroundColor = [UIColor greenColor];
self.tableArray = [[NSMutableArray alloc]init];
self.talbeListArray = [[NSMutableArray alloc]init];
self.changeFlage = NO;
}
return self;
}
//创建textfiled子控件
- (void)addViewTextfiled:(CGRect)frame{
UITextField * textfield = [[UITextField alloc]initWithFrame:CGRectMake(0, 0, frame.size.width, frame.size.height)];
self.ZJtextfield = textfield;
textfield.backgroundColor = [UIColor grayColor];
[self addSubview:textfield];
}
以上实现后我们来进行格式化 在textfiled 输入变化时 调用这个方法并且根据不同的模式进行不同的格式化
#pragma mark 输入的内容改变时调用这个方法 使用时必须实现
- (BOOL)ZJtextField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string{
if (self.ZJTextfieldStyle == ZJTextfieldStyleBank) {
return [self bankNumberTextField:textField shouldChangeCharactersInRange:range replacementString:string];
}
if (self.ZJTextfieldStyle == ZJTextfieldStylePhone) {
return [self phoneNumberTextField:textField shouldChangeCharactersInRange:range replacementString:string];
}else if (self.ZJTextfieldStyle == ZJTextfieldStyleTableList){
return NO;
}else if (self.ZJTextfieldStyle == ZJTextFieldStyleAccount){
NSString * str = [NSString stringWithFormat:@"%@%@",textField.text,string];
[self zjtextfiledCountSearchPredicate:str];
return YES;
}else{
return YES;
}
}
#pragma mark 手机号码格式
- (BOOL)phoneNumberTextField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string{
if (textField.text.length >12 && ![string isEqualToString:@""]) {
return NO;
}else if ([string isEqualToString:@" "]) {
NSLog(@"不能输入空格");
return NO;
}else if(![string isEqualToString:@""]){
// NSLog(@"====%@ string = %@",textField.text,string);
if ((textField.text.length - byteNilFlag)%byteNil == 0 && (textField.text.length - byteNilFlag)/byteNil != 0 && string.length > 0) {
byteNilFlag = byteNilFlag + byteNil; byteNil = 5;
NSMutableString * str = [NSMutableString stringWithFormat:@"%@ ",textField.text];
textField.text = str;
}
NSString * str = [NSString stringWithFormat:@"%@%@",textField.text,string];
[self zjtextfiledCountSearchPredicate:str];
return YES;
}else{
//删除是遇到空格多删除一位
if ([[textField.text substringWithRange:range] isEqualToString:@" "]) {
NSRange deleteRange = NSMakeRange(0, textField.text.length - 1);
NSString * str = [textField.text substringWithRange:deleteRange];
textField.text = str;
}
if (textField.text.length < 3) {
byteNil = 3;
byteNilFlag = 0;
}
if(textField.text.length <= byteNilFlag){
byteNilFlag = byteNilFlag - byteNil;
}
NSString * str = [NSString stringWithFormat:@"%@%@",textField.text,string];
[self zjtextfiledCountSearchPredicate:str];
return YES;
}
}
#pragma mark 银行卡格式化
- (BOOL)bankNumberTextField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string{
//NSLog();
if (textField.text.length > 19 + 3 && ![string isEqualToString:@""]){
return NO;
}else if ([string isEqualToString:@" "]) {
NSLog(@"不能输入空格");
return NO;
}else if(![string isEqualToString:@""]){
// NSLog(@"====%@ string = %@",textField.text,string);
if ((textField.text.length - byteNilFlagBank)%byteNilBank == 0 && (textField.text.length - byteNilFlagBank)/byteNilBank != 0 && string.length > 0) {
byteNilFlagBank = byteNilFlagBank + byteNilBank;
byteNilBank = 5;
NSMutableString * str = [NSMutableString stringWithFormat:@"%@ ",textField.text];
textField.text = str;
}
NSString * str = [NSString stringWithFormat:@"%@%@",textField.text,string];
[self zjtextfiledCountSearchPredicate:str]; return YES;
}else{
//删除是遇到空格多删除一位
if ([[textField.text substringWithRange:range] isEqualToString:@" "]) {
NSRange deleteRange = NSMakeRange(0, textField.text.length - 1);
NSString * str = [textField.text substringWithRange:deleteRange];
textField.text = str;
}
if (textField.text.length < 4) {
byteNilBank = 4; byteNilFlagBank = 0;
}
if(textField.text.length <= byteNilFlagBank){
byteNilFlagBank = byteNilFlagBank - byteNilBank;
}
NSString * str = [NSString stringWithFormat:@"%@%@",textField.text,string];
[self zjtextfiledCountSearchPredicate:str];
return YES;
}
}