iOS中输入框设置指定字符输入的方法

 更新时间:2018年01月11日 10:30:18   作者:刘高见  
这篇文章主要给大家介绍了关于iOS中输入框如何设置指定字符输入的相关资料,其中介绍了关于只能输入纯数字、只能输入纯大小写字母以及大小写字母和数字结合输入等指定字符的限制,需要的朋友可以参考借鉴,下面来一起看看吧。

前言

对于开发者来说,在很多情况下,一般的输入框需要按照要求进行输入,输入内容由开发人员来指定。例如:密码输入框只能输入纯数字或者是拼音与数字结合的文本等,那么我们在开发的时候就需要做一些输入文本的限时。下面话不多说了,来一起看看详细的介绍吧。

一、只能输入纯数字

在这里以UITextField为例:其实现代码如下:

- (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string {
 return [self validateNumber:string];
}
- (BOOL)validateNumber:(NSString*)number {
 BOOL res = YES;
 NSCharacterSet* tmpSet = [NSCharacterSet characterSetWithCharactersInString:@"0123456789"];
 int i = 0;
 while (i < number.length) {
 NSString * string = [number substringWithRange:NSMakeRange(i, 1)];
 NSRange range = [string rangeOfCharacterFromSet:tmpSet];
 if (range.length == 0) {
  res = NO;
  break;
 }
 i++;
 }
 return res;
}

另外我们还有一种更加简便的方法来实现这一目的:

首先宏定义

#define NUMBER @"0123456789"

接着

- (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string
{
 NSCharacterSet *cs = [[NSCharacterSet characterSetWithCharactersInString:NUMBER] invertedSet];
 NSString *filtered = [[string componentsSeparatedByCharactersInSet:cs] componentsJoinedByString:@""];
 return [string isEqualToString:filtered];
}

二、只能输入纯大小写字母

和以上只能输入纯数字类似,实现起来简单,只需要宏定义

#define LETTER @"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz"

然后实现

- (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string
{
 NSCharacterSet *cs = [[NSCharacterSet characterSetWithCharactersInString:LETTER] invertedSet];
 NSString *filtered = [[string componentsSeparatedByCharactersInSet:cs] componentsJoinedByString:@""];
 return [string isEqualToString:filtered];
}

三、大小写字母和数字结合输入

对照以上

#define LETTER_NUMBER @"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789"

同样道理具体能够输入那些内容如果输入内容能够一一列举的话我们就可以通过define来设置了,实现起来超简单。

限制只能输入中文

在这里用到了观察者(更多观察者模式的介绍参考这里:https://www.jb51.net/article/76122.htm

- (void)viewDidLoad {
 [super viewDidLoad];
 _myTextField.delegate = self;
 [[NSNotificationCenter defaultCenter]addObserver:self selector:@selector(textFiledEditChanged:) name:UITextFieldTextDidChangeNotification object:_myTextField];
}
- (BOOL)textFieldShouldReturn:(UITextField *)textField{
 [textField resignFirstResponder]; 
 //过滤非汉字字符
 textField.text = [self filterCharactor:textField.text withRegex:@"[^\u4e00-\u9fa5]"]; 
 if (textField.text.length >= 4) {
  textField.text = [textField.text substringToIndex:4];  
 }
 return NO;
}
- (void)textFiledEditChanged:(id)notification{
 UITextRange *selectedRange = _myTextField.markedTextRange;
 UITextPosition *position = [_myTextField positionFromPosition:selectedRange.start offset:0];
 
 if (!position) { //// 没有高亮选择的字
  //过滤非汉字字符
  _myTextField.text = [self filterCharactor:_myTextField.text withRegex:@"[^\u4e00-\u9fa5]"];
  
  if (_myTextField.text.length >= 4) {
   _myTextField.text = [_myTextField.text substringToIndex:4];
  }
 }else { //有高亮文字
  //do nothing
 }
}
- (NSString *)filterCharactor:(NSString *)string withRegex:(NSString *)regexStr{
 NSString *searchText = string;
 NSError *error = NULL;
 NSRegularExpression *regex = [NSRegularExpression regularExpressionWithPattern:regexStr options:NSRegularExpressionCaseInsensitive error:&error];
 NSString *result = [regex stringByReplacingMatchesInString:searchText options:NSMatchingReportCompletion range:NSMakeRange(0, searchText.length) withTemplate:@""];
 return result;
}
- (void)dealloc{
 [[NSNotificationCenter defaultCenter] removeObserver:self];
}

如果要限制输入字符位数的话可以直接设置,这个实现上有很多种,最简单的就是

- (void)textViewDidChange:(UITextView *)textView{
 NSInteger number = [textView.text length];
 if (number > 300) {
  textView.text = [textView.text substringToIndex:300];
 }
}

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对脚本之家的支持。

相关文章

  • 教你如何解决XCODE升级后插件不能用问题

    教你如何解决XCODE升级后插件不能用问题

    Xcode 每次更新有个很头疼的问题,就是插件都会失效,要重装。 不得不说好多插件还是非常方便能提高效率。那么如何来解决这个问题呢,今天我们就来探讨下。
    2015-11-11
  • iOS App中UILabel的自定义及在Auto Layout中的使用

    iOS App中UILabel的自定义及在Auto Layout中的使用

    这篇文章主要介绍了iOS App中UILabel的自定义及在Auto Layout中的使用,示例代码为传统的Objective-C语言,需要的朋友可以参考下
    2016-03-03
  • ios开发加载webview显示进度条实例

    ios开发加载webview显示进度条实例

    本篇文章主要介绍了ios开发加载webview显示进度条实例,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-05-05
  • iOS 11 UINavigationItem 去除左右间隙的方法

    iOS 11 UINavigationItem 去除左右间隙的方法

    本篇文章主要介绍了iOS 11 UINavigationItem 去除左右间隙的方法,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧
    2017-10-10
  • 详解iOS应用开发中autoresizing尺寸自动适应属性的用法

    详解iOS应用开发中autoresizing尺寸自动适应属性的用法

    这篇文章主要介绍了iOS应用开发中autoresizing尺寸自动适应属性的用法,文中讲解了使用代码和Storyboard两种方式调节autoresizing的方法,示例代码为Objective-C,需要的朋友可以参考下
    2016-03-03
  • 详解Xcode编译选项功能

    详解Xcode编译选项功能

    本篇文章详细分析了一下Xcode编译选项功能以及相关的介绍,有这方面需要的参考学下下。
    2018-01-01
  • 详解适配iOS10 的相关权限设置

    详解适配iOS10 的相关权限设置

    在最新版本的iOS10系统中,如果你的项目中访问了隐私数据,比如:相机、相册、录音、定位、联系人等等。涉及到权限问题,本篇文章主要介绍了适配iOS10 的相关权限设置,有兴趣的可以了解一下。
    2016-12-12
  • iOS优雅的将CALayer旋转360度示例代码

    iOS优雅的将CALayer旋转360度示例代码

    CALayer我们又称它叫做层,CALayer类的概念与UIView非常类似,并且可以包含图片、文本、背景色等。下面这篇文章主要给大家介绍了关于iOS如何优雅的将CALayer旋转360度的相关资料,文中通过示例代码的非常详细,需要的朋友可以参考借鉴,下面来一起看看吧。
    2018-01-01
  • 浅谈iOS开发如何适配暗黑模式(Dark Mode)

    浅谈iOS开发如何适配暗黑模式(Dark Mode)

    这篇文章主要介绍了浅谈iOS开发如何适配暗黑模式(Dark Mode),文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2019-09-09
  • iOS开发中音频工具类的封装以及音乐播放器的细节控制

    iOS开发中音频工具类的封装以及音乐播放器的细节控制

    这篇文章主要介绍了iOS开发中音频工具类的封装以及音乐播放器的细节控制,代码基于传统的Objective-C,需要的朋友可以参考下
    2015-12-12

最新评论