iOS中輸入框設(shè)置指定字符輸入的方法
前言
對于開發(fā)者來說,在很多情況下,一般的輸入框需要按照要求進(jìn)行輸入,輸入內(nèi)容由開發(fā)人員來指定。例如:密碼輸入框只能輸入純數(shù)字或者是拼音與數(shù)字結(jié)合的文本等,那么我們在開發(fā)的時候就需要做一些輸入文本的限時。下面話不多說了,來一起看看詳細(xì)的介紹吧。
一、只能輸入純數(shù)字
在這里以UITextField為例:其實(shí)現(xiàn)代碼如下:
- (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;
}
另外我們還有一種更加簡便的方法來實(shí)現(xiàn)這一目的:
首先宏定義
#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];
}
二、只能輸入純大小寫字母
和以上只能輸入純數(shù)字類似,實(shí)現(xiàn)起來簡單,只需要宏定義
#define LETTER @"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz"
然后實(shí)現(xiàn)
- (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];
}
三、大小寫字母和數(shù)字結(jié)合輸入
對照以上
#define LETTER_NUMBER @"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789"
同樣道理具體能夠輸入那些內(nèi)容如果輸入內(nèi)容能夠一一列舉的話我們就可以通過define來設(shè)置了,實(shí)現(xiàn)起來超簡單。
限制只能輸入中文
在這里用到了觀察者(更多觀察者模式的介紹參考這里:http://www.dhdzp.com/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];
}
如果要限制輸入字符位數(shù)的話可以直接設(shè)置,這個實(shí)現(xiàn)上有很多種,最簡單的就是
- (void)textViewDidChange:(UITextView *)textView{
NSInteger number = [textView.text length];
if (number > 300) {
textView.text = [textView.text substringToIndex:300];
}
}
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
iOS App中UILabel的自定義及在Auto Layout中的使用
這篇文章主要介紹了iOS App中UILabel的自定義及在Auto Layout中的使用,示例代碼為傳統(tǒng)的Objective-C語言,需要的朋友可以參考下2016-03-03
ios開發(fā)加載webview顯示進(jìn)度條實(shí)例
本篇文章主要介紹了ios開發(fā)加載webview顯示進(jìn)度條實(shí)例,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-05-05
iOS 11 UINavigationItem 去除左右間隙的方法
本篇文章主要介紹了iOS 11 UINavigationItem 去除左右間隙的方法,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2017-10-10
詳解iOS應(yīng)用開發(fā)中autoresizing尺寸自動適應(yīng)屬性的用法
這篇文章主要介紹了iOS應(yīng)用開發(fā)中autoresizing尺寸自動適應(yīng)屬性的用法,文中講解了使用代碼和Storyboard兩種方式調(diào)節(jié)autoresizing的方法,示例代碼為Objective-C,需要的朋友可以參考下2016-03-03
詳解適配iOS10 的相關(guān)權(quán)限設(shè)置
在最新版本的iOS10系統(tǒng)中,如果你的項(xiàng)目中訪問了隱私數(shù)據(jù),比如:相機(jī)、相冊、錄音、定位、聯(lián)系人等等。涉及到權(quán)限問題,本篇文章主要介紹了適配iOS10 的相關(guān)權(quán)限設(shè)置,有興趣的可以了解一下。2016-12-12
iOS優(yōu)雅的將CALayer旋轉(zhuǎn)360度示例代碼
CALayer我們又稱它叫做層,CALayer類的概念與UIView非常類似,并且可以包含圖片、文本、背景色等。下面這篇文章主要給大家介紹了關(guān)于iOS如何優(yōu)雅的將CALayer旋轉(zhuǎn)360度的相關(guān)資料,文中通過示例代碼的非常詳細(xì),需要的朋友可以參考借鑒,下面來一起看看吧。2018-01-01
淺談iOS開發(fā)如何適配暗黑模式(Dark Mode)
這篇文章主要介紹了淺談iOS開發(fā)如何適配暗黑模式(Dark Mode),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2019-09-09
iOS開發(fā)中音頻工具類的封裝以及音樂播放器的細(xì)節(jié)控制
這篇文章主要介紹了iOS開發(fā)中音頻工具類的封裝以及音樂播放器的細(xì)節(jié)控制,代碼基于傳統(tǒng)的Objective-C,需要的朋友可以參考下2015-12-12

