UITextField常用屬性歸納:文本框樣式、文字樣式、鍵盤樣式、左右視圖樣式、清除按鈕設置等


(1)可以根據需要設置文本框的樣式(包括形狀、邊框顏色、背景等)。

 

(2)可以根據需要設置文字顯示樣式(包括輸入密碼時的密文顯示、文字橫向居中、縱向居中上下、輸入的文字是否首席木大寫、文字超過后是否縮小還是向右滾動等)。

 

(3)可以根據需要設置各種不同的鍵盤樣式(只有數字、只有字母等等)。

 

(4)還有inputView可以彈出一個視圖,用於取代彈出鍵盤,暫時不知道什么用處,但貌似可以用得地方很多啊。

 

(5)還有return的樣式設置,可以設置為Google也可以設置為Go和Search等更形象的按鈕。

 

(6)還有一個clearsOnBeginEditing是否設置清除按鈕也很常用。

 

(7)還有用得比較多得估計是左右視圖,也就是我們常見的用戶名和密碼的前面還有一個小icon圖片表示用戶的“小人”和表示密碼的“鎖”的圖片,用左右視圖可以加載進來,當然最后要記得設置左右視圖模式為Always,不然默認是Never不顯示的。

 

 

[objc]  view plain copy 技術分享 技術分享
 
  1. - (void)viewDidLoad {  
  2.     //textfiled1本想是textField1的,但不影響  
  3.     UITextField *textFiled1=[[UITextField alloc]init];  
  4.     //此時textField1已存在,但因為是透明背景,所以看不見,但是點擊那塊地方會發現光標閃爍可寫  
  5.     //為了證明是透明背景而不是白色背景,我們可以設置self.view背景為紅色,看看textField1是白色還是透明色  
  6. //    self.view.backgroundColor=[UIColor redColor];  
  7.     textFiled1.frame=CGRectMake(10, 30, 300, 30);  
  8.     //設置邊框樣式  
  9.     //UITextBorderStyleRoundedRect-圓角矩形,背景是白色,不再是透明的  
  10.     //UITextBorderStyleLine-矩形,黑色邊框,透明背景  
  11.     //UITextBorderStyleBezel-和上面類似,但是是灰色的邊框,背景透明  
  12.     textFiled1.borderStyle=UITextBorderStyleRoundedRect;  
  13.     //設置背景顏色,會覆蓋上面圓角矩形默認的白色背景  
  14.     textFiled1.backgroundColor=[UIColor purpleColor];  
  15.     //設置提示(默認)文字  
  16.     textFiled1.placeholder=@"請輸入您的密碼";  
  17.     //設置密文輸入,就是和輸入密碼時類似的顯示為小圓點  
  18.     textFiled1.secureTextEntry=YES;  
  19.     //設置鍵盤樣式,比如銀行取款密碼只需要數字,有的輸入郵箱需要@等等  
  20.     //UIKeyboardTypeAlphabet和UIKeyboardTypeDefault類似,就是我們平時看到那樣,都是字母,然后有個按鍵可以切換符號  
  21.     //UIKeyboardTypeASCIICapable好像和上面差不多  
  22.     //UIKeyboardTypeDecimalPad,UIKeyboardTypeNumberPad都是數字,但前者多了一個“小數點”按鍵  
  23.     [email protected]�  
  24.     //UIKeyboardTypeNamePhonePad-貌似正常  
  25.     //UIKeyboardTypePhonePad-電話鍵盤,不僅有數字還有*和#的那種  
  26.     //UIKeyboardTypeNumbersAndPunctuation-只有數字和標點符號  
  27.     //UIKeyboardTypeTwitter-除了字母還有@和#,這是微博的符號  
  28.     //UIKeyboardTypeURL-除字母,還有.com按鈕,方便輸入  
  29.     //UIKeyboardTypeWebSearch-主要區別在於return鍵變成了GO鍵  
  30.     //注意:如果是最xcode6下的模擬器的話,默認是不調出軟鍵盤的,按CMD+K可以調出,或者在菜單Hardware里地Keyboard里設置  
  31.     textFiled1.keyboardType=UIKeyboardTypeWebSearch;  
  32.     //設置鍵盤外觀  
  33.     //UIKeyboardAppearanceDark和UIKeyboardAppearanceAlert都是把鍵盤背景變成半透明灰色區別不明顯  
  34.     //UIKeyboardAppearanceLight貌似和UIKeyboardAppearanceDefault一樣,沒啥區別  
  35.     textFiled1.keyboardAppearance=UIKeyboardAppearanceAlert;  
  36.       
  37.     //設置彈出視圖,inputView即彈出的不是鍵盤而是這個視圖  
  38.     //設置的frame時,只有高度有用,其他x和y和寬都是無效的,寬是默認的整個鍵盤寬度  
  39.     UIImageView *imgView1=[[UIImageView alloc]initWithImage:[UIImage imageNamed:@"logo-60@3x.png"]];  
  40.     imgView1.frame=CGRectMake(60, 60, 300, 300);  
  41.     textFiled1.inputView=imgView1;  
  42.       
  43.     //設置左視圖,就是用戶名和密碼,有時候放個圖片的位置  
  44.     UIView *view1=[[UIView alloc]init];  
  45.     //x和y無效,x都是0,而y是根據高度來自動調整的。即高度如果超過textField則默認是textField高,如小於textField高度,則上下居中顯示。唯一有效的就是寬度  
  46.     view1.frame=CGRectMake(10, 500, 50, 10);  
  47.     view1.backgroundColor=[UIColor orangeColor];  
  48.     textFiled1.leftView=view1;  
  49.     //最重要的時:默認它是不顯示的即UITextFieldViewModeNever,我們可以設置永遠顯示UITextFieldViewModeAlways  
  50.     //UITextFieldViewModeUnlessEditing-一開始就有,點擊框,呃,貌似還有  
  51.     //UITextFieldViewModeWhileEditing-一開始沒有,點擊框就出現  
  52.     textFiled1.leftViewMode=UITextFieldViewModeAlways;  
  53.       
  54.     //同樣,我們可以設置右視圖,當然也可以加載和圖片進來  
  55.     UIImageView *imgView2=[[UIImageView alloc]initWithImage:[UIImage imageNamed:@"logo-60@3x.png"]];  
  56.     imgView2.frame=CGRectMake(10, 500, 50, 10);  
  57.     textFiled1.rightView=imgView2;  
  58.     textFiled1.rightViewMode=UITextFieldViewModeAlways;  
  59.       
  60.     //設置清除按鈕,就是那個叉叉X,一點擊整個輸入框的文字全部刪除重新輸入的那個X(我們先注釋掉不讓右視圖顯示,來查看效果)  
  61.     //其實我們在寫clearButtonMode是它又提示說這是一個UITextFieldViewMode類型,所以也是和上面一樣  
  62.     textFiled1.clearButtonMode=UITextFieldViewModeWhileEditing;  
  63.       
  64.     //再次編輯時是否清空內容,這個除特定場景外很少用,會讓用戶抓狂的  
  65.     //當然為了模擬再次編輯,我們需要鼠標點到其他地方然后再點回來,所以再創建一個textField  
  66.     textFiled1.clearsOnBeginEditing=NO;  
  67.     //這個clearsOnInsertion貌似點擊回去再次編輯時不清楚,但是只要一輸入內容就會清除之前的  
  68.     textFiled1.clearsOnInsertion=YES;  
  69.     UITextField *textField2=[[UITextField alloc]init];  
  70.     textField2.frame=CGRectMake(10, 80, 300, 100);  
  71.     textField2.borderStyle=UITextBorderStyleRoundedRect;  
  72.     [self.view addSubview:textField2];  
  73.       
  74.     //我們用上面創建的textField2來做如下  
  75.     //縱向對齊方式,默認是居中  
  76.     //UIControlContentVerticalAlignmentCenter居中,所以Top、Bottom就是居上居下。Fill貌似和Top差不多  
  77.     textField2.contentVerticalAlignment=UIControlContentVerticalAlignmentFill;  
  78.     //當然還有橫向對齊  
  79.     //也有左中右和Fill四種,但是貌似沒看到什么效果,可能對文字無效,因為有專門的針對文字的設置  
  80.     textField2.contentHorizontalAlignment=UIControlContentHorizontalAlignmentRight;  
  81.     //設置文字對齊方式  
  82.     //同樣我們輸入textAlignment時有提示是NSTextAlignment類型,有好幾種,不細講  
  83.     textField2.textAlignment=NSTextAlignmentCenter;  
  84.     //設置調整文字大小以適配寬度(即輸入不下時縮小文字,實在縮小不了了,就向后滾動),默認是向右滾動的  
  85.     textField2.adjustsFontSizeToFitWidth=YES;  
  86.     //設置最小字號,和上面有關,即小於這個字號的時候,我就不縮小了,直接向右滾動  
  87.     textField2.minimumFontSize=2;  
  88.     //設置字母大小樣式,輸入autocapitalizationType時有提示是UITextAutocapitalizationType類型  
  89.     //UITextAutocapitalizationTypeAllCharacters-所有字母大寫(用鍵盤輸入的話發現失效,需要用軟鍵盤輸入才有效,以下同理)  
  90.     //UITextAutocapitalizationTypeWords-單詞首字母大寫  
  91.     //UITextAutocapitalizationTypeSentences-句首字母大寫  
  92.     textField2.autocapitalizationType=UITextAutocapitalizationTypeSentences;  
  93.       
  94.     //設置return樣式,有Done/Go/Next/Join/Google/Search/Yahoo/EmergencyCall/Send等,除了默認外,其他的按鈕都是藍顏色背景  
  95.     textField2.returnKeyType=UIReturnKeyEmergencyCall;  
  96.       
  97.     [self.view addSubview:textFiled1];  
  98.       
  99.     [super viewDidLoad];  
  100.     // Do any additional setup after loading the view, typically from a nib.  
  101. }  


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM