iOS實現(xiàn)一個意見反饋類型的輸入欄
前言
本文主要給大家介紹了關(guān)于利用iOS如何實現(xiàn)一個意見反饋類型的輸入欄,分享出來供大家參考學(xué)習(xí),下面話不多說了,來一起看看詳細的介紹吧。
要做個意見反饋,TextField只有一行,TextView沒有提示,好尬,只有做一個了,就是使用TextView作為輸入框,添加個label作為提示,這里的關(guān)鍵是輸入內(nèi)容的限制,我這里限制了120字,但是要考慮很多方面的東西,來看代碼
示例代碼
@property (nonatomic, strong) UILabel *placholderLabel; //提示字符串 @property (weak, nonatomic) IBOutlet UITextView *infoTF; #define MAX_LIMIT_NUMS 120 //文本最大長度 - (void)controlView { self.infoTF.layer.borderWidth = 0.5;//邊寬 self.infoTF.layer.cornerRadius = 5.0;//設(shè)置圓角 self.infoTF.layer.borderColor =[UIColor grayColor].CGColor; self.infoTF.delegate = self; CGFloat width = self.infoTF.frame.size.width; self.placholderLabel = [[UILabel alloc] initWithFrame:CGRectMake(5, 0, width-5, 30)]; self.placholderLabel.numberOfLines = 0; self.placholderLabel.text = setInternational(@"live.weibosummay.string"); self.placholderLabel.textColor = setRGBColor(176, 176, 176); self.placholderLabel.font = ZKP15Font; [self.placholderLabel setHidden:NO]; [self.infoTF addSubview:_placholderLabel]; } //限制文本輸入長度 - (void)textViewDidChange:(UITextView*)textView{ if([textView.text length] == 0){ _placholderLabel.hidden = NO; }else{ _placholderLabel.hidden = YES;//這里給空 } UITextRange *selectedRange = [textView markedTextRange]; //獲取高亮部分 UITextPosition *pos = [textView positionFromPosition:selectedRange.start offset:0]; //如果在變化中是高亮部分在變,就不要計算字符了 if (selectedRange && pos) { return; } NSString *nsTextContent = textView.text; NSInteger existTextNum = nsTextContent.length; if (existTextNum > MAX_LIMIT_NUMS){ //截取到最大位置的字符(由于超出截部分在should時被處理了所在這里這了提高效率不再判斷) NSString *s = [nsTextContent substringToIndex:MAX_LIMIT_NUMS]; [textView setText:s]; } } //設(shè)置超出最大字數(shù)(120字)即不可輸入 也是textview的代理方法 - (BOOL)textView:(UITextView*)textView shouldChangeTextInRange:(NSRange)range replacementText:(NSString*)text{ UITextRange *selectedRange = [textView markedTextRange]; //獲取高亮部分 UITextPosition *pos = [textView positionFromPosition:selectedRange.start offset:0]; //如果有高亮且當(dāng)前字數(shù)開始位置小于最大限制時允許輸入 if (selectedRange && pos) { NSInteger startOffset = [textView offsetFromPosition:textView.beginningOfDocument toPosition:selectedRange.start]; NSInteger endOffset = [textView offsetFromPosition:textView.beginningOfDocument toPosition:selectedRange.end]; NSRange offsetRange = NSMakeRange(startOffset, endOffset - startOffset); if (offsetRange.location < MAX_LIMIT_NUMS) { return YES; }else{ return NO; } } NSString *comcatstr = [textView.text stringByReplacingCharactersInRange:range withString:text]; NSInteger caninputlen = MAX_LIMIT_NUMS - comcatstr.length; if (caninputlen >= 0){ return YES; }else{ NSInteger len = text.length + caninputlen; //防止當(dāng)text.length + caninputlen < 0時,使得rg.length為一個非法最大正數(shù)出錯 NSRange rg = {0,MAX(len,0)}; if (rg.length > 0){ NSString *s = @""; //判斷是否只普通的字符或asc碼(對于中文和表情返回NO) BOOL asc = [text canBeConvertedToEncoding:NSASCIIStringEncoding]; if (asc) { s = [text substringWithRange:rg];//因為是ascii碼直接取就可以了不會錯 }else{ __block NSInteger idx = 0; __block NSString *trimString = @"";//截取出的字串 //使用字符串遍歷,這個方法能準確知道每個emoji是占一個unicode還是兩個 [text enumerateSubstringsInRange:NSMakeRange(0, [text length]) options:NSStringEnumerationByComposedCharacterSequences usingBlock: ^(NSString* substring, NSRange substringRange, NSRange enclosingRange, BOOL* stop) { NSInteger steplen = substring.length; if (idx >= rg.length) { *stop = YES; //取出所需要就break,提高效率 return ; } trimString = [trimString stringByAppendingString:substring]; idx = idx + steplen;//這里變化了,使用了字串占的長度來作為步長 }]; s = trimString; } //rang是指從當(dāng)前光標處進行替換處理(注意如果執(zhí)行此句后面返回的是YES會觸發(fā)didchange事件) [textView setText:[textView.text stringByReplacingCharactersInRange:range withString:s]]; } return NO; } }
總結(jié)
以上就是這篇文章的全部內(nèi)容了,本文還有許多不足,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
iOS開發(fā)之UITableView左滑刪除等自定義功能
今天來給大家介紹下iOS開發(fā)中UITableView左滑實現(xiàn)微信中置頂,刪除等功能。對大家開發(fā)iOS具有一定的參考借鑒價值,有需要的朋友們一起來看看吧。2016-09-09iOS開發(fā)之導(dǎo)航欄各種右滑返回失效的解決方法匯總
這篇文章主要給大家總結(jié)介紹了關(guān)于iOS開發(fā)教程之導(dǎo)航欄各種右滑返回失效的解決方法,文中通過示例代碼介紹的非常詳細,對各位iOS具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧2018-08-08iOS實現(xiàn)支持小數(shù)的星星評分組件實例代碼
程序中需要打分的功能,在網(wǎng)上找了幾個,都不是很滿意。所以自己動手實現(xiàn)了一個,下面這篇文章主要給大家介紹了關(guān)于利用iOS實現(xiàn)支持小數(shù)的星星評分組件的相關(guān)資料,需要的朋友可以參考借鑒,下面來一起看看吧。2017-08-08IOS如何使用CAShapeLayer實現(xiàn)復(fù)雜的View的遮罩效果
這篇文章主要為大家詳細介紹了IOS如何使用CAShapeLayer實現(xiàn)復(fù)雜的View的遮罩效果,感興趣的小伙伴們可以參考一下2016-03-03iOS開發(fā)之級聯(lián)界面(推薦界面)搭建原理
這篇文章主要為大家詳細介紹了iOS級聯(lián)界面(推薦界面)搭建原理,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-08-08iOS ScrollView嵌套tableView聯(lián)動滾動的思路與最佳實踐
這篇文章主要給大家介紹了關(guān)于ScrollView嵌套tableView聯(lián)動滾動的思路與最佳實踐,文中通過示例代碼介紹的非常詳細,對各位iOS開發(fā)者們具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧2019-10-10