UITextFiled的使用總結(jié)

一.代碼設(shè)置UITextFiled

(1) //初始化textfield并設(shè)置位置及大小

UITextField*text = [[UITextFieldalloc]initWithFrame:CGRectMake(20,20,130,30)];

[self.viewaddSubview:text];

(2)//設(shè)置邊框樣式心软,只有設(shè)置了才會(huì)顯示邊框樣式

text.borderStyle=UITextBorderStyleRoundedRect;

typedefNS_ENUM(NSInteger, UITextBorderStyle) {

UITextBorderStyleNone,

UITextBorderStyleLine,

UITextBorderStyleBezel,

UITextBorderStyleRoundedRect

};

(3)//設(shè)置輸入框的背景顏色,如果使用了自定義的背景圖片邊框會(huì)被忽略掉

text.backgroundColor= [UIColorgrayColor];

(4)//設(shè)置背景

//注意:只有在UITextBorderStyleNone樣式下晦嵌,設(shè)置背景圖才會(huì)生效局雄,且圖片大小小于text的frame時(shí),圖片會(huì)拉伸

text.background= [UIImageimageNamed:@"tupian1"];

//這個(gè)屬性聲明了是否啟用這個(gè)UIControl對(duì)象,注意不是userInteractionEnabled

text.enabled=NO;

//設(shè)置enable為NO時(shí)的背景圖片,必須UITextBorderStyleNone樣式下

text.disabledBackground= [UIImageimageNamed:@"tupian2"];

(5)//占位符

text.placeholder=@"password";

(6)//設(shè)置占位文字字體顏色

[textsetValue:[UIColorredColor]forKeyPath:@"_placeholderLabel.textColor"];

或者:

UIColor*color = [UIColorgreenColor];

text.attributedPlaceholder= [[NSAttributedStringalloc]initWithString:@"網(wǎng)批號(hào)"attributes:@{NSForegroundColorAttributeName: color}];

(7)//設(shè)置文字字體和大小

//遍歷字體名稱

for(NSString*strin[UIFontfamilyNames]) {

NSLog(@"UIFont_name: %@",str);

}

字體只有英文和數(shù)字有效

text.font= [UIFontfontWithName:@"Arial"size:20];

text.font= [UIFontsystemFontOfSize:24];

(8)//第一響應(yīng)者

//文本框變成第一相應(yīng)者

[self.textFieldbecomeFirstResponder];

//取消第一響應(yīng)者身份

撤銷某個(gè)UITextField的第一響應(yīng)者

[self.textFieldresignFirstResponder];

或者

[self.viewendEditing:YES];

(9)//輸入框中一開(kāi)始就有的文字

text.text=@"zhangfa";

(10)//設(shè)置字體顏色

text.textColor= [UIColorredColor];

(11)//輸入框中是否有個(gè)叉號(hào)脐雪,在什么時(shí)候顯示宣虾,用于一次性刪除輸入框中的內(nèi)容

//點(diǎn)擊自動(dòng)刪除文字,不需要手動(dòng)關(guān)聯(lián)方法

text.clearButtonMode=UITextFieldViewModeAlways;

typedefNS_ENUM(NSInteger, UITextFieldViewMode) {

UITextFieldViewModeNever,

UITextFieldViewModeWhileEditing,//編輯時(shí)出現(xiàn)

UITextFieldViewModeUnlessEditing,//除了編輯外都出現(xiàn)

UITextFieldViewModeAlways

};

(12)//每輸入一個(gè)字符就變成點(diǎn)用語(yǔ)密碼輸入

text.secureTextEntry=YES;

(13)//定義文本是否使用iPhone的自動(dòng)更正功能

text.autocorrectionType=UITextAutocorrectionTypeNo;

typedefNS_ENUM(NSInteger, UITextAutocorrectionType) {

UITextAutocorrectionTypeDefault,//默認(rèn)

UITextAutocorrectionTypeNo,//不自動(dòng)糾錯(cuò)

UITextAutocorrectionTypeYes,//自動(dòng)糾錯(cuò)

};

(14)//再次編輯就清空

text.clearsOnBeginEditing=YES;

(15)//內(nèi)容對(duì)齊方式

text.textAlignment=UITextAlignmentLeft;

//內(nèi)容的垂直對(duì)齊方式

/*

內(nèi)容對(duì)齊方式

內(nèi)容的垂直對(duì)齊方式UITextField繼承自UIControl,此類中有一個(gè)屬性contentVerticalAlignment

*/

text.contentVerticalAlignment=UIControlContentVerticalAlignmentCenter;

(16)//設(shè)置為YES時(shí)文本會(huì)自動(dòng)縮小以適應(yīng)文本窗口大小.默認(rèn)是保持原來(lái)大小,而讓長(zhǎng)文本滾動(dòng)

text.adjustsFontSizeToFitWidth=YES;

//設(shè)置自動(dòng)縮小顯示的最小字體大小畜份,adjustsFontSizeToFitWidth為YES才會(huì)起作用

text.minimumFontSize=10;

(17)//設(shè)置鍵盤(pán)的樣式

text.keyboardType=UIKeyboardTypeNumberPad;

typedef enum {

UIKeyboardTypeDefault,????  默認(rèn)鍵盤(pán),支持所有字符

UIKeyboardTypeASCIICapable, 支持ASCII的默認(rèn)鍵盤(pán)

UIKeyboardTypeNumbersAndPunctuation, 標(biāo)準(zhǔn)電話鍵盤(pán)淘正,支持+*#字符

UIKeyboardTypeURL,??????????? URL鍵盤(pán),支持.com按鈕?只支持URL字符

UIKeyboardTypeNumberPad,???????????  數(shù)字鍵盤(pán)

UIKeyboardTypePhonePad,   電話鍵盤(pán)

UIKeyboardTypeNamePhonePad,  電話鍵盤(pán)臼闻,也支持輸入人名

UIKeyboardTypeEmailAddress,  用于輸入電子?郵件地址的鍵盤(pán)

UIKeyboardTypeDecimalPad,??  數(shù)字鍵盤(pán)?有數(shù)字和小數(shù)點(diǎn)

UIKeyboardTypeTwitter,?????  優(yōu)化的鍵盤(pán)辞做,方便輸入@蛉幸、#字符

UIKeyboardTypeAlphabet = UIKeyboardTypeASCIICapable,

} UIKeyboardType;

(18)//首字母是否大寫(xiě)

text.autocapitalizationType=UITextAutocapitalizationTypeNone;

typedef enum {

UITextAutocapitalizationTypeNone,?不自動(dòng)大寫(xiě)

UITextAutocapitalizationTypeWords, 單詞首字母大寫(xiě)

UITextAutocapitalizationTypeSentences, 句子的首字母大寫(xiě)

UITextAutocapitalizationTypeAllCharacters,?所有字母都大寫(xiě)

} UITextAutocapitalizationType;

(19)//return鍵變成什么鍵

text.returnKeyType=UIReturnKeyDone;

typedef enum {

UIReturnKeyDefault,?默認(rèn)?灰色按鈕,標(biāo)有Return

UIReturnKeyGo,???  標(biāo)有Go的藍(lán)色按鈕

UIReturnKeyGoogle,標(biāo)有Google的藍(lán)色按鈕,用語(yǔ)搜索

UIReturnKeyJoin,標(biāo)有Join的藍(lán)色按鈕

UIReturnKeyNext,標(biāo)有Next的藍(lán)色按鈕

UIReturnKeyRoute,標(biāo)有Route的藍(lán)色按鈕

UIReturnKeySearch,標(biāo)有Search的藍(lán)色按鈕

UIReturnKeySend,標(biāo)有Send的藍(lán)色按鈕

UIReturnKeyYahoo,標(biāo)有Yahoo的藍(lán)色按鈕

UIReturnKeyYahoo,標(biāo)有Yahoo的藍(lán)色按鈕

UIReturnKeyEmergencyCall,?緊急呼叫按鈕

} UIReturnKeyType;

(20)//鍵盤(pán)外觀

text.keyboardAppearance=UIKeyboardAppearanceAlert;

typedef enum {

UIKeyboardAppearanceDefault乍惊,?默認(rèn)外觀,淺灰色

UIKeyboardAppearanceAlert商源,   深灰?石墨色

} UIReturnKeyType;

(21)//最右側(cè)加圖片,左側(cè)類似,XY設(shè)置無(wú)效

UIImageView*image=[[UIImageViewalloc]initWithFrame:CGRectMake(0,0,20,20)];

image.image= [UIImageimageNamed:@"項(xiàng)目icon"];

text.rightView=image;

text.rightViewMode=UITextFieldViewModeAlways;

typedef enum {

UITextFieldViewModeNever,

UITextFieldViewModeWhileEditing,

UITextFieldViewModeUnlessEditing,

UITextFieldViewModeAlways

} UITextFieldViewMode;

(22) 重寫(xiě)繪制行為

除了UITextField對(duì)象的風(fēng)格選項(xiàng)萨驶,你還可以定制化UITextField對(duì)象,為他添加許多不同的重寫(xiě)方法缤谎,來(lái)改變文本字段的顯示行為抒倚。這些方法都會(huì)返回一個(gè)CGRect結(jié)構(gòu),制定了文本字段每個(gè)部件的邊界范圍坷澡。以下方法都可以重寫(xiě)托呕。

–?textRectForBounds:  ?  //重寫(xiě)來(lái)重置文字區(qū)域

–?drawTextInRect:  ?????  //改變繪文字屬性.重寫(xiě)時(shí)調(diào)用super可以按默認(rèn)圖形屬性繪制,若自己完全重寫(xiě)繪制函數(shù),就不用調(diào)用super了.

–?placeholderRectForBounds:  //重寫(xiě)來(lái)重置占位符區(qū)域

–?drawPlaceholderInRect:  //重寫(xiě)改變繪制占位符屬性.重寫(xiě)時(shí)調(diào)用super可以按默認(rèn)圖形屬性繪制,若自己完全重寫(xiě)繪制函數(shù)频敛,就不用調(diào)用super了.

–?borderRectForBounds:  //重寫(xiě)來(lái)重置邊緣區(qū)域

–?editingRectForBounds:  //重寫(xiě)來(lái)重置編輯區(qū)域

–?clearButtonRectForBounds:  //重寫(xiě)來(lái)重置clearButton位置,改變size可能導(dǎo)致button的圖片失真

–?leftViewRectForBounds:

–?rightViewRectForBounds:

代理方法:UITextFieldDelegate協(xié)議

//按return鍵鍵盤(pán)往下收becomeFirstResponder

//返回一個(gè)BOOL值项郊,指明是否允許在按下回車鍵時(shí)結(jié)束編輯

- (BOOL)textFieldShouldReturn:(UITextField*)textField

{

[self.textField resignFirstResponder];

returnYES;

}

//開(kāi)始編輯時(shí)觸發(fā),文本字段將成為first responder

- (void)textFieldDidBeginEditing:(UITextField*)textField

{

}

//返回YES斟赚,輸入內(nèi)容后着降,點(diǎn)擊右邊的清除按鈕可以清除,返回NO拗军,點(diǎn)擊清除不起作用

- (BOOL)textFieldShouldClear:(UITextField*)textField{

//返回一個(gè)BOOL值指明是否允許根據(jù)用戶請(qǐng)求清除內(nèi)容

//可以設(shè)置在特定條件下才允許清除內(nèi)容

returnYES;

}

- (BOOL)textFieldShouldBeginEditing:(UITextField*)textField

{

//返回一個(gè)BOOL值任洞,指定是否循序文本字段開(kāi)始編輯,返回NO時(shí)不能喚起鍵盤(pán)進(jìn)行編輯

returnYES;

}

- (BOOL)textFieldShouldEndEditing:(UITextField*)textField{

//返回BOOL值蓄喇,指定是否允許文本字段結(jié)束編輯,當(dāng)編輯結(jié)束交掏,文本字段會(huì)讓出first responder

//要想在用戶結(jié)束編輯時(shí)阻止文本字段消失妆偏,可以返回NO

//這對(duì)一些文本字段必須始終保持活躍狀態(tài)的程序很有用,比如即時(shí)消息

returnNO;//一直處于編輯狀態(tài)

}

- (BOOL)textField:(UITextField*)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString*)string{

//當(dāng)用戶使用自動(dòng)更正功能盅弛,把輸入的文字修改為推薦的文字時(shí)钱骂,就會(huì)調(diào)用這個(gè)方法。

//這對(duì)于想要加入撤銷選項(xiàng)的應(yīng)用程序特別有用

//可以跟蹤字段內(nèi)所做的最后一次修改挪鹏,也可以對(duì)所有編輯做日志記錄,用作審計(jì)用途见秽。

//要防止文字被改變可以返回NO

//這個(gè)方法的參數(shù)中有一個(gè)NSRange對(duì)象,指明了被改變文字的位置讨盒,建議修改的文本也在其中

returnYES;

}

通知:

UITextField派生自UIControl解取,所以UIControl類中的通知系統(tǒng)在文本字段中也可以使用。

除了UIControl類的標(biāo)準(zhǔn)事件催植,你還可以使用下列UITextField類特有的事件.

//只有這三個(gè)

UITextFieldTextDidBeginEditingNotification

UITextFieldTextDidChangeNotification

UITextFieldTextDidEndEditingNotification//當(dāng)文本字段退出編輯模式時(shí)觸發(fā)肮蛹。通知的object屬性存儲(chǔ)了最終文本

因?yàn)槲谋咀侄我褂面I盤(pán)輸入文字,所以下面這些事件發(fā)生時(shí)创南,也會(huì)發(fā)送動(dòng)作通知

UIKeyboardWillShowNotification  //鍵盤(pán)顯示之前發(fā)送

UIKeyboardDidShowNotification?  //鍵盤(pán)顯示之后發(fā)送

UIKeyboardWillHideNotification  //鍵盤(pán)隱藏之前發(fā)送

UIKeyboardDidHideNotification?  //鍵盤(pán)隱藏之后發(fā)送

二.在storyboard中設(shè)置UITextField

1伦忠、Text?:設(shè)置文本框的默認(rèn)文本。

2稿辙、Placeholder?:

3昆码、Background?:

4、Disabled?:?若選中此項(xiàng)邻储,用戶將不能更改文本框內(nèi)容赋咽。

5、接下來(lái)是三個(gè)按鈕吨娜,用來(lái)設(shè)置對(duì)齊方式脓匿。

6、Border Style?:?選擇邊界風(fēng)格宦赠。

7陪毡、Clear Button?:?這是一個(gè)下拉菜單,你可以選擇清除按鈕什么時(shí)候出現(xiàn)

7.1 Never appears?:?從不出現(xiàn)

7.2 Appears while editing?:?編輯時(shí)出現(xiàn)

7.3 Appears unless editing?:

7.4 Is always visible?:?總是可見(jiàn)

8勾扭、Clear when editing begins?:?若選中此項(xiàng)毡琉,則當(dāng)開(kāi)始編輯這個(gè)文本框時(shí),文本框中之前的內(nèi)容會(huì)被清除掉妙色。比如桅滋,你現(xiàn)在這個(gè)文本框?A?中輸入了?"What"?,之后去編輯文本框?B身辨,若再回來(lái)編輯文本框?A?丐谋,則其中的?"What"?會(huì)被立即清除芍碧。

9、Text Color?:?設(shè)置文本框中文本的顏色号俐。

10师枣、Font?:?設(shè)置文本的字體與字號(hào)。

11萧落、Min Font Size?:?設(shè)置文本框可以顯示的最小字體

12、Adjust To Fit?:?指定當(dāng)文本框尺寸減小時(shí)洗贰,文本框中的文本是否也要縮小找岖。選擇它,可以使得全部文本都可見(jiàn)敛滋,即使文本很長(zhǎng)许布。但是這個(gè)選項(xiàng)要跟?Min Font Size?配合使用,文本再縮小绎晃,也不會(huì)小于設(shè)定的?Min Font Size?蜜唾。

接下來(lái)的部分用于設(shè)置鍵盤(pán)如何顯示。

13庶艾、Captitalization?:?設(shè)置大寫(xiě)袁余。下拉菜單中有四個(gè)選項(xiàng):

13.1 None?:?不設(shè)置大寫(xiě)

13.2 Words?:?每個(gè)單詞首字母大寫(xiě),這里的單詞指的是以空格分開(kāi)的字符串

13.3 Sentances?:?每個(gè)句子的第一個(gè)字母大寫(xiě)咱揍,這里的句子是以句號(hào)加空格分開(kāi)的字符串

13.4 All Characters?:?所以字母大寫(xiě)

14颖榜、Correction?:?檢查拼寫(xiě),默認(rèn)是?YES?煤裙。

15掩完、Keyboard?:?選擇鍵盤(pán)類型,比如全數(shù)字硼砰、字母和數(shù)字等且蓬。

16、Appearance:

17题翰、Return Key?:?選擇返回鍵恶阴,可以選擇?Search?、?Return?遍愿、?Done?等存淫。

18、Auto-enable Return Key?:?如選擇此項(xiàng)沼填,則只有至少在文本框輸入一個(gè)字符后鍵盤(pán)的返回鍵才有效桅咆。

19、Secure?:?當(dāng)你的文本框用作密碼輸入框時(shí)坞笙,可以選擇這個(gè)選項(xiàng)岩饼,此時(shí)荚虚,字符顯示為星號(hào)。

1.Alignment Horizontal?水平對(duì)齊方式

2.Alignment Vertical?垂直對(duì)齊方式

3.用于返回一個(gè)BOOL值 輸入框是否?Selected(選中) Enabled(可用) Highlighted(高亮)

三.限制只能輸入特定的字符

(1)限制只能輸入特定的字符

下面那個(gè)NUMBERS是一個(gè)宏籍茧,可以在文件頂部定義:

#define NUMBERS @”0123456789n”?(這個(gè)代表可以輸入數(shù)字和換行版述,請(qǐng)注意這個(gè)n,如果不寫(xiě)這個(gè)寞冯,Done按鍵將不會(huì)觸發(fā)渴析,如果用在SearchBar中,將會(huì)不觸發(fā)Search事件吮龄,因?yàn)槟阕约合拗撇蛔屳斎雗俭茧,好慘漓帚,我在項(xiàng)目中才發(fā)現(xiàn)的母债。)

所以尝抖,如果你要限制輸入英文和數(shù)字的話,就可以把這個(gè)定義為:

#define kAlphaNum?? @”ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789″昧辽。

當(dāng)然衙熔,你還可以在以上方法return之前奴迅,做一提示的青责,比如提示用戶只能輸入數(shù)字之類的取具。如果你覺(jué)得有需要的話脖隶。

-(BOOL)textField:(UITextField*)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString*)string{

NSCharacterSet*cs;

//invertedSet方法是去反字符,把所有的除了NUMBERS里的字符都找出來(lái)(包含去空格功能)

cs = [[NSCharacterSetcharacterSetWithCharactersInString:NUMBERS]invertedSet];

// componentsJoinedByString用于根據(jù)一個(gè)字符串來(lái)將數(shù)組連接成一個(gè)新的字符串。

NSString*filtered = [[stringcomponentsSeparatedByCharactersInSet:cs]componentsJoinedByString:@""];//按cs分離出數(shù)組,數(shù)組按@""分離出字符串

BOOLcanChange = [stringisEqualToString:filtered];

returncanChange;

//這樣寫(xiě)了以后暇检,輸入非數(shù)字時(shí)不能輸入

}

(2)限制只能輸入一定長(zhǎng)度的字符

- (BOOL)textField:(UITextField*)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString*)string

{

//string就是此時(shí)輸入的那個(gè)字符textField就是此時(shí)正在輸入的那個(gè)輸入框返回YES就是可以改變輸入框的值NO相反

if([stringisEqualToString:@"n"])//按會(huì)車可以改變//這里這個(gè)字符寫(xiě)什么,就只能輸入什么

{

returnYES;

}

NSString* toBeString = [textField.textstringByReplacingCharactersInRange:rangewithString:string];//得到輸入框的內(nèi)容

if(self.textField== textField)//判斷是否時(shí)我們想要限定的那個(gè)輸入框

{

if([toBeStringlength] >20) {//如果輸入框內(nèi)容大于20則彈出警告

textField.text= [toBeStringsubstringToIndex:20];

//UIAlertView *alert = [[[UIAlertView alloc] initWithTitle:nil message:@"超過(guò)最大字?jǐn)?shù)不能輸入了" delegate:nil cancelButtonTitle:@"Ok" otherButtonTitles:nil, nil] autorelease]; //iOS8.3以后用

// UIAlertController

//[alert show];

returnNO;

}

}

returnYES;

}

5.UITextField的屬性:

inputView:鍵盤(pán),可用UIDatePicker或者UIPickerView覆蓋

inputAccessoryView:鍵盤(pán)頂部的導(dǎo)航欄,用UIToolbar覆蓋

3.?可以在UITextField使用下面方法构蹬,按return鍵返回

-(IBAction)?textFieldDone:(id)?sender

{

[textFieldName?resignFirstResponder];

}

鏈接TextField控件的"Did?end?on?exit"

最右側(cè)加圖片是以下代碼,

UIImageView?*imgv=[[UIImageView?alloc]?initWithImage:[UIImage?imageNamed:@"right.png"]];

text.rightView=imgv;

text.rightViewMode?=?UITextFieldViewModeAlways;

如果是在最左側(cè)加圖片就換成:

text.leftView=imgv;

text.leftViewMode?=?UITextFieldViewModeAlways;

UITextField?繼承自?UIControl,此類中有一個(gè)屬性contentVerticalAlignment

所以想讓UITextField里面的text垂直居中可以這樣寫(xiě):

text.contentVerticalAlignment?=?UIControlContentVerticalAlignmentCenter;

查看函數(shù)的方法:

按住command鍵雙擊進(jìn)入函數(shù)聲明

按住alt鍵雙擊進(jìn)入doc文檔

///////////////////////////////////////////////////////////////

文本框常用方法:

如何用程序刪除文本框中選中的文本

[textView?delete:?nil];

///////////////////////////////////////////////////////////////

如何限制文本框只能輸入數(shù)字:

建立NSNumberFormatter的子類悔据,增加這個(gè)方法,將formatter鏈接至文本框科汗。

-?(BOOL)?isPartialStringValid:?(NSString?**)?partialStringPtr

proposedSelectedRange:?(NSRangePointer)?proposedSelRangePtr

originalString:?(NSString?*)?origString

originalSelectedRange:?(NSRange)?origSelRange

errorDescription:?(NSString?**)?error

{

NSCharacterSet?*nonDigits;

NSRange?newStuff;

NSString?*newStuffString;

nonDigits?=?[[NSCharacterSet?decimalDigitCharacterSet]?invertedSet];

newStuff?=?NSMakeRange(origSelRange.location,

proposedSelRangePtr->location

-?origSelRange.location);

newStuffString?=?[*partialStringPtr?substringWithRange:?newStuff];

if([newStuffString?rangeOfCharacterFromSet:?nonDigits

options:?NSLiteralSearch].location?!=?NSNotFound)?{

*error?=@"不是數(shù)字";

return(NO);

}else{

*error?=?nil;

return(YES);

}

}

///////////////////////////////////////////////////////////////

從文本框獲取十六進(jìn)制數(shù)據(jù)的代碼

charsingleNumberString[3]?=?{'\0','\0','\0'};

uint32_t?singleNumber?=0;

uint32_t?i?=0;

NSMutableData?*data?=?[NSMutableData?data];

//從文本框獲取到得數(shù)據(jù)

constchar*buf?=?[[_hexToSendTextField?text]?UTF8String];

//轉(zhuǎn)換為十六進(jìn)制

for(i?=0;?i?<?strlen(buf);?i+=2)

{

if(((i+1)?<?len?&&?isxdigit(buf)?&&?(isxdigit(buf[i+1])))

{

singleNumberString[0]?=?buf;

singleNumberString[1]?=?buf[i+1];

sscanf(singleNumberString,"%x",?&singleNumber);

[data?appendBytes:(void*)(&tmp)?length:1];

}

else

{

break;

}

}

//輸出

NSLog(@"%@",?data);

/////////////////////////////////////////////////////////////

點(diǎn)擊?UITextView?輸入文字,光標(biāo)都從最初點(diǎn)開(kāi)始

-?(void)textViewDidChangeSelection:(UITextView?*)textView

{

NSRange?range;

range.location?=0;

range.length?=0;

textView.selectedRange?=?range;

}

3.?可以在UITextField使用下面方法怖亭,按return鍵返回

-(IBAction)?textFieldDone:(id)?sender

{

[textFieldName?resignFirstResponder];

}

鏈接TextField控件的"Did?end?on?exit"

////////////////////////////////////////////////////////////////////

限制輸入文本的長(zhǎng)度

-?(BOOL)textField:(UITextField?*)textField?shouldChangeCharactersInRange:(NSRange)range?replacementString:(NSString?*)string

{

if(range.location?>=?MAX_LENGTH)

returnNO;//return?NO?to?not?change?text

returnYES;

}

if(textField.text.length?>=10&&?range.length?==0)

returnNO;

returnYES;

-?(BOOL)textField:(UITextField?*)textField?shouldChangeCharactersInRange:(NSRange)range?replacementString:(NSString?*)string

{

if([textField.text?length]?>?MAXLENGTH)

{

textField.text?=?[textField.text?substringToIndex:MAXLENGTH-1];

returnNO;

}

returnYES;

}

//////////////////////////////////////////////////////////////////////

使用UITextFieldDelegate來(lái)隱藏鍵盤(pán)

在iPhone界面上,時(shí)常會(huì)需要當(dāng)用戶輸入完內(nèi)容后期吓,隱藏鍵盤(pán)倾芝。?當(dāng)然有很多方法,今天只介紹使用UITextFieldDelegate這個(gè)協(xié)議實(shí)現(xiàn)隱藏鍵盤(pán)晨另。

其實(shí)很簡(jiǎn)單,?需要三步:

1.?在你的控制器類中拯刁,加入U(xiǎn)ITextFieldDelegate這個(gè)協(xié)議

如:@interfaceAddItemViewController?:?UIViewController?

2.?在使用了UITextFieldDelegate協(xié)議的控制器類的實(shí)現(xiàn)中逝段,加入-?(BOOL)textFieldShouldReturn:方法。

-?(BOOL)textFieldShouldReturn:(UITextField?*)textField?{

[textField?resignFirstResponder];

returnYES;

}

//設(shè)置焦點(diǎn):

[UITextField?becomeFirstResponder];

3.?將xib文件中的TextField控件的delegate變量指向到之前使用UITextFieldDelegate協(xié)議的那個(gè)控制器類,將?TextField的delegate?IBOutlet變量右鍵鏈接到前面的控制器類的實(shí)例上帚桩。或者使用代碼方式账嚎,指定相關(guān)TextField的delegate變量。

-?(void)viewDidLoad

{

[super?viewDidLoad];

itemNameField.delegate=?self;

priceField.delegate=?self;

}

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
  • 序言:七十年代末郭蕉,一起剝皮案震驚了整個(gè)濱河市喂江,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌获询,老刑警劉巖,帶你破解...
    沈念sama閱讀 216,402評(píng)論 6 499
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件梢薪,死亡現(xiàn)場(chǎng)離奇詭異尝哆,居然都是意外死亡秉撇,警方通過(guò)查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,377評(píng)論 3 392
  • 文/潘曉璐 我一進(jìn)店門赴邻,熙熙樓的掌柜王于貴愁眉苦臉地迎上來(lái)啡捶,“玉大人,你說(shuō)我怎么就攤上這事瞎暑。” “怎么了了赌?”我有些...
    開(kāi)封第一講書(shū)人閱讀 162,483評(píng)論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長(zhǎng)袄秩。 經(jīng)常有香客問(wèn)我逢并,道長(zhǎng)之剧,這世上最難降的妖魔是什么砍聊? 我笑而不...
    開(kāi)封第一講書(shū)人閱讀 58,165評(píng)論 1 292
  • 正文 為了忘掉前任,我火速辦了婚禮蟹肘,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘帘腹。我一直安慰自己许饿,他們只是感情好竹椒,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,176評(píng)論 6 388
  • 文/花漫 我一把揭開(kāi)白布米辐。 她就那樣靜靜地躺著胸完,像睡著了一般翘贮。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上狸页,一...
    開(kāi)封第一講書(shū)人閱讀 51,146評(píng)論 1 297
  • 那天扯再,我揣著相機(jī)與錄音址遇,去河邊找鬼。 笑死秃殉,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的钾军。 我是一名探鬼主播绢要,決...
    沈念sama閱讀 40,032評(píng)論 3 417
  • 文/蒼蘭香墨 我猛地睜開(kāi)眼,長(zhǎng)吁一口氣:“原來(lái)是場(chǎng)噩夢(mèng)啊……” “哼重罪!你這毒婦竟也來(lái)了?” 一聲冷哼從身側(cè)響起剿配,我...
    開(kāi)封第一講書(shū)人閱讀 38,896評(píng)論 0 274
  • 序言:老撾萬(wàn)榮一對(duì)情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒(méi)想到半個(gè)月后围俘,有當(dāng)?shù)厝嗽跇?shù)林里發(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,311評(píng)論 1 310
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡簿寂,尸身上長(zhǎng)有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,536評(píng)論 2 332
  • 正文 我和宋清朗相戀三年宿亡,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片挽荠。...
    茶點(diǎn)故事閱讀 39,696評(píng)論 1 348
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖漠另,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情笆搓,我是刑警寧澤,帶...
    沈念sama閱讀 35,413評(píng)論 5 343
  • 正文 年R本政府宣布满败,位于F島的核電站,受9級(jí)特大地震影響算墨,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜骇扇,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,008評(píng)論 3 325
  • 文/蒙蒙 一面粮、第九天 我趴在偏房一處隱蔽的房頂上張望少孝。 院中可真熱鬧熬苍,春花似錦、人聲如沸柴底。這莊子的主人今日做“春日...
    開(kāi)封第一講書(shū)人閱讀 31,659評(píng)論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽(yáng)鸿脓。三九已至抑钟,卻和暖如春野哭,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背拨黔。 一陣腳步聲響...
    開(kāi)封第一講書(shū)人閱讀 32,815評(píng)論 1 269
  • 我被黑心中介騙來(lái)泰國(guó)打工, 沒(méi)想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留贺待,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 47,698評(píng)論 2 368
  • 正文 我出身青樓狠持,卻偏偏與公主長(zhǎng)得像瞻润,于是被迫代替她去往敵國(guó)和親甜刻。 傳聞我的和親對(duì)象是個(gè)殘疾皇子正勒,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 44,592評(píng)論 2 353

推薦閱讀更多精彩內(nèi)容