欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

iOS實現(xiàn)一個意見反饋類型的輸入欄

 更新時間:2017年10月20日 11:15:53   作者:隨風(fēng)  
這篇文章主要給大家介紹了關(guān)于利用iOS實現(xiàn)一個意見反饋類型的輸入欄,通過文中實現(xiàn)的輸入欄會用戶一個很好的體驗效果,文中給了詳細的示例代碼,需要的朋友可以參考借鑒,下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧。

前言

本文主要給大家介紹了關(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左滑刪除等自定義功能

    今天來給大家介紹下iOS開發(fā)中UITableView左滑實現(xiàn)微信中置頂,刪除等功能。對大家開發(fā)iOS具有一定的參考借鑒價值,有需要的朋友們一起來看看吧。
    2016-09-09
  • IOS實現(xiàn)圓形圖片效果的兩種方法

    IOS實現(xiàn)圓形圖片效果的兩種方法

    這篇文章介紹在IOS中如何實現(xiàn)圓形圖片,實現(xiàn)后的效果很贊,有需要的可以參考借鑒。
    2016-08-08
  • iOS APP中保存圖片到相冊時崩潰的解決方法

    iOS APP中保存圖片到相冊時崩潰的解決方法

    下面小編就為大家分享一篇iOS APP中保存圖片到相冊時崩潰的解決方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2017-12-12
  • iOS開發(fā)之導(dǎo)航欄各種右滑返回失效的解決方法匯總

    iOS開發(fā)之導(dǎo)航欄各種右滑返回失效的解決方法匯總

    這篇文章主要給大家總結(jié)介紹了關(guān)于iOS開發(fā)教程之導(dǎo)航欄各種右滑返回失效的解決方法,文中通過示例代碼介紹的非常詳細,對各位iOS具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-08-08
  • iOS實現(xiàn)支持小數(shù)的星星評分組件實例代碼

    iOS實現(xiàn)支持小數(shù)的星星評分組件實例代碼

    程序中需要打分的功能,在網(wǎng)上找了幾個,都不是很滿意。所以自己動手實現(xiàn)了一個,下面這篇文章主要給大家介紹了關(guān)于利用iOS實現(xiàn)支持小數(shù)的星星評分組件的相關(guān)資料,需要的朋友可以參考借鑒,下面來一起看看吧。
    2017-08-08
  • IOS如何使用CAShapeLayer實現(xiàn)復(fù)雜的View的遮罩效果

    IOS如何使用CAShapeLayer實現(xiàn)復(fù)雜的View的遮罩效果

    這篇文章主要為大家詳細介紹了IOS如何使用CAShapeLayer實現(xiàn)復(fù)雜的View的遮罩效果,感興趣的小伙伴們可以參考一下
    2016-03-03
  • iOS音樂播放器實現(xiàn)代碼完整版

    iOS音樂播放器實現(xiàn)代碼完整版

    這篇文章主要為大家詳細介紹了iOS音樂播放器實現(xiàn)代碼完整版,包括音頻列表、播放器、后臺播放、鎖屏播放,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2018-05-05
  • iOS開發(fā)之級聯(lián)界面(推薦界面)搭建原理

    iOS開發(fā)之級聯(lián)界面(推薦界面)搭建原理

    這篇文章主要為大家詳細介紹了iOS級聯(lián)界面(推薦界面)搭建原理,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2016-08-08
  • iOS中仿QQ側(cè)滑菜單功能

    iOS中仿QQ側(cè)滑菜單功能

    這篇文章主要介紹了iOS中仿QQ側(cè)滑菜單功能,在實現(xiàn)此功能之前,需要先了解UITabBarController的層級結(jié)構(gòu),具體實現(xiàn)思路大家可以參考下本文
    2017-07-07
  • iOS ScrollView嵌套tableView聯(lián)動滾動的思路與最佳實踐

    iOS ScrollView嵌套tableView聯(lián)動滾動的思路與最佳實踐

    這篇文章主要給大家介紹了關(guān)于ScrollView嵌套tableView聯(lián)動滾動的思路與最佳實踐,文中通過示例代碼介紹的非常詳細,對各位iOS開發(fā)者們具有一定的參考學(xué)習(xí)價值,需要的朋友們下面來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10

最新評論