Objective-C:多行文字輸入框(UITextView)
初始化並定義大小 基礎屬性設定
UITextView *textview = [[UITextView alloc] initWithFrame:CGRectMake(20, 10, 280, 30)];
textview.backgroundColor=[UIColor whiteColor]; //背景色
textview.scrollEnabled = NO; //當文字超過檢視的邊框時是否允許滑動,預設為“YES”
textview.editable = YES; //是否允許編輯內容,預設為“YES”
textview.delegate = self; //設定代理方法的實現類
textview.font=[UIFont fontWithName:@"Arial" size:18.0]; //設定字型名字和字型大小;
textview.returnKeyType = UIReturnKeyDefault;//return鍵的型別
textview.keyboardType = UIKeyboardTypeDefault;//鍵盤型別
textview.textAlignment = NSTextAlignmentLeft; //文字顯示的位置預設為居左
textview.dataDetectorTypes = UIDataDetectorTypeAll; //顯示資料型別的連線模式(如電話號碼、網址、地址等)
textview.textColor = [UIColor blackColor];
textview.text = @"UITextView詳解";//設定顯示的文字內容
[self.view addSubview:textview];
UITextView的代理方法如下:
//將要開始編輯
- (BOOL)textViewShouldBeginEditing:(UITextView *)textView;
//將要結束編輯
- (BOOL)textViewShouldEndEditing:(UITextView *)textView;
//開始編輯
- (void)textViewDidBeginEditing:(UITextView *)textView;
//結束編輯
- (void)textViewDidEndEditing:(UITextView *)textView;
//內容將要發生改變編輯
- (BOOL)textView:(UITextView *)textView shouldChangeTextInRange:(NSRange)range replacementText:(NSString*)text;
//內容發生改變編輯
- (void)textViewDidChange:(UITextView *)textView;
//焦點發生改變
- (void)textViewDidChangeSelection:(UITextView *)textView;
有時候我們要控制元件自適應輸入的文字的內容的高度,只要在textViewDidChange的代理方法中加入調整控制元件大小的代理即可
- (void)textViewDidChange:(UITextView *)textView{
//計算文字的高度
CGSize constraintSize;
constraintSize.width = textView.frame.size.width-16;
constraintSize.height = MAXFLOAT;
CGSize sizeFrame =[textView.text sizeWithFont:textView.font
constrainedToSize:constraintSize
lineBreakMode:UILineBreakModeWordWrap];
//重新調整textView的高度
textView.frame = CGRectMake(textView.frame.origin.x,textView.frame.origin.y,textView.frame.size.width,sizeFrame.height+5);
}
控制輸入文字的長度和內容,可通呼叫以下代理方法實現
- (BOOL)textView:(UITextView *)textView shouldChangeTextInRange:(NSRange)range replacementText:(NSString*)text{
if (range.location>=100) {
//控制輸入文字的長度
return NO;
}
if ([text isEqualToString:@"\n"]) {
//禁止輸入換行
return NO;
}else{
return YES;
}
}
UITextView退出鍵盤的幾種方式-因為iphone的軟鍵盤沒有自帶的退鍵盤鍵,所以要實現退出鍵盤需要自己實現,有如下幾種方式:
1)如果你程式是有導航條的,可以在導航條上面加多一個Done的按鈕,用來退出鍵盤,當然要先實UITextViewDelegate。
- (void)textViewDidBeginEditing:(UITextView *)textView {
UIBarButtonItem *done = [[UIBarButtonItem alloc] initWithBarButtonSystemItem:UIBarButtonSystemItemDone target:self action:@selector(dismissKeyBoard)];
self.navigationItem.rightBarButtonItem = done;
[done release];
done = nil;
}
- (void)textViewDidEndEditing:(UITextView *)textView {
self.navigationItem.rightBarButtonItem = nil;
}
- (void)dismissKeyBoard {
[self.textView resignFirstResponder];
}
2)如果你的textview裡不用Enter鍵,可以把Enter鍵當做退出鍵盤的響應鍵。程式碼如下:
-(BOOL)textView:(UITextView *)textView shouldChangeTextInRange:(NSRange)range replacementText:(NSString*)text{
if ([text isEqualToString:@"\n"]) {
[textView resignFirstResponder];
return NO;
}
return YES;
}
3)還有你也可以自定義其他載入鍵盤上面用來退出,比如在彈出的鍵盤上面加一個view來放置退出鍵盤的Done按鈕。程式碼如下:
UIToolbar * topView = [[UIToolbar alloc]initWithFrame:CGRectMake(0, 0, 320, 30)];
[topView setBarStyle:UIBarStyleBlack];
UIBarButtonItem *btnSpace = [[UIBarButtonItem alloc]initWithBarButtonSystemItem:UIBarButtonSystemItemFlexibleSpace target:self action:nil];
UIBarButtonItem *doneButton = [[UIBarButtonItem alloc]initWithTitle:@"Done" style:UIBarButtonItemStyleDone target:self action:@selector(dismissKeyBoard)];
NSArray * buttonsArray = @[btnSpace, doneButton];;
[doneButton release];
[btnSpace release];
[topView setItems:buttonsArray];
[textView setInputAccessoryView:topView];//當文字輸入框加上topView
[topView release];
topView = nil;
-(IBAction)dismissKeyBoard{
[tvTextView resignFirstResponder];
}
相關文章
- 自定義UITextView輸入框UITextView
- 實現高度“聽話”的多行文字輸入框
- UITextView如何精準限制文字輸入長度UITextView
- input只能輸入文字框
- HTML textarea 多行文字框HTML
- HTML textarea多行文字框HTML
- 文字框輸入文字倒計詳解
- iOS -UITextField/UITextView之鍵盤遮擋輸入框解決方法iOSUITextView
- 實現textarea文字框多行提示文字效果
- JavaScript 文字框只能輸入數字JavaScript
- JavaScript 文字框輸入內容同步JavaScript
- jQuery文字框輸入內容同步jQuery
- javascript限制文字框輸入長度JavaScript
- JS 文字輸入框放大鏡效果JS
- 文字框只能輸入數字 javascriptJavaScript
- 文字框限制輸入字數的JSJS
- 文字框只能輸入數字程式碼
- jQuery文字框內容輸入同步功能jQuery
- Axure之解決文字框無法輸入
- 限定文字框輸入字串長度程式碼字串
- javascript規定文字框不能夠輸入空格JavaScript
- jQuery限制文字框輸入長度詳解jQuery
- iOS 文字輸入框隨鍵盤上移iOS
- PyQT5之單行文字輸入到多行顯示窗QT
- Web聊天工具的富文字輸入框Web
- Qt 實現文字輸入框,帶字數限制QT
- js多個文字框輸入內容同步效果JS
- javascript實時顯示文字框輸入字數JavaScript
- textarea文字框輸入文字數目倒計效果程式碼例項
- JavaScript實時計算輸入文字框字元數量JavaScript字元
- html input文字輸入框的一些總結HTML
- 限定文字框只能輸入數字例項程式碼
- js實現的文字框只能夠輸入數字JS
- 文字框輸入數字倒計例項程式碼
- 限制文字框只能輸入數字:Asp.net&C#ASP.NETC#
- asp.net input文字框只能輸入數字jsASP.NETJS
- Flutter 密碼輸入框 驗證碼輸入框Flutter密碼
- react輸入框輸入中文bugReact