当前位置: 移动技术网 > 移动技术>移动开发>IOS > iOS实现一个意见反馈类型的输入栏

iOS实现一个意见反馈类型的输入栏

2019年07月24日  | 移动技术网移动技术  | 我要评论

前言

本文主要给大家介绍了关于利用ios如何实现一个意见反馈类型的输入栏,分享出来供大家参考学习,下面话不多说了,来一起看看详细的介绍吧。

要做个意见反馈,textfield只有一行,textview没有提示,好尬,只有做一个了,就是使用textview作为输入框,添加个label作为提示,这里的关键是输入内容的限制,我这里限制了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;//设置圆角
 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];
 }
}
//设置超出最大字数(120字)即不可输入 也是textview的代理方法
- (bool)textview:(uitextview*)textview shouldchangetextinrange:(nsrange)range
 replacementtext:(nsstring*)text{
 
 uitextrange *selectedrange = [textview markedtextrange];
 //获取高亮部分
 uitextposition *pos = [textview positionfromposition:selectedrange.start offset:0];
 
 //如果有高亮且当前字数开始位置小于最大限制时允许输入
 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;
  //防止当text.length + caninputlen < 0时,使得rg.length为一个非法最大正数出错
  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是指从当前光标处进行替换处理(注意如果执行此句后面返回的是yes会触发didchange事件)
   [textview settext:[textview.text stringbyreplacingcharactersinrange:range withstring:s]];
  }
  return no;
 }
}

总结

以上就是这篇文章的全部内容了,本文还有许多不足,希望本文的内容对大家的学习或者工作具有一定的参考学习价值,如果有疑问大家可以留言交流,谢谢大家对移动技术网的支持。

如对本文有疑问, 点击进行留言回复!!

相关文章:

验证码:
移动技术网