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];
}
相關文章
- 實現高度“聽話”的多行文字輸入框
- HTML textarea 多行文字框HTML
- 文字框輸入文字倒計詳解
- 文字框文字輸入數量倒計效果
- JavaScript 文字框只能輸入數字JavaScript
- 文字框限制輸入字數效果
- 文字框限制輸入字數的JSJS
- Axure之解決文字框無法輸入
- Web聊天工具的富文字輸入框Web
- Qt 實現文字輸入框,帶字數限制QT
- PyQT5之單行文字輸入到多行顯示窗QT
- 輸入框
- JavaScript實時計算輸入文字框字元數量JavaScript字元
- html input文字輸入框的一些總結HTML
- Flutter 密碼輸入框 驗證碼輸入框Flutter密碼
- react輸入框輸入中文bugReact
- jQuery文字框輸入數字彈出格式化層jQuery
- WPF 自定義文字框輸入法 IME 跟隨游標
- input 輸入框只能輸入數字
- 從一次輸入框無法輸入的bug,談如何限制輸入框輸入型別型別
- 直播小程式原始碼,react-native自定義文字輸入框原始碼React
- 動態顯示:文字框字數(輸入還剩多少字)
- imemode 控制輸入法,控制輸入框的輸入法
- 直播軟體開發,限制富文字框輸入的字元數上限字元
- 利用 Angular Directive 和 @HostBinding 實現輸入文字框隨著鍵盤輸入自動變色效果Angular
- flutter TextField 輸入框元件Flutter元件
- Input 輸入框中 只能輸入正整數
- CSS 多行文字居中CSS
- Flutter 驗證碼輸入框Flutter
- 輸入框換行問題
- UITextView UITextField限制輸入字數以及精準剩餘字數顯示UITextView
- QT學習筆記(三)單行文字輸入框與自動補全QT筆記
- 直播系統原始碼,Vue 禁止輸入框輸入空格原始碼Vue
- cad動態輸入框不見了 cad動態輸入框怎麼調出來
- JavaScript–文字框中只允許輸入數字的操作(其他字元不顯示)JavaScript字元
- 關於輸入框的細節
- input輸入框的各種事件事件
- Element UI Input框輸入無效UI