網(wǎng)上有很多限制textField輸入長度方法,但是我覺得都不是很完美,準(zhǔn)確來說可以說是不符合實(shí)際開發(fā)的要求,因此在這里整理一下textField限制輸入長度的方法.
	 我所采用的并不是監(jiān)聽方法而是最不同的代理實(shí)現(xiàn)方法,為什么不使用監(jiān)聽呢???
	 當(dāng)你看到這篇文章很有可能視是為一件事所苦惱那就是使用監(jiān)聽限制輸入長度后不能夠完美的控制輸入內(nèi)容.
舉一個(gè)簡單的例子:
你要限制輸入長度為30個(gè)字符,當(dāng)你輸入30個(gè)字符后監(jiān)聽的確可以很好的控制不讓你繼續(xù)輸入,但是問題也隨之而來,當(dāng)你把光標(biāo)移動到輸入內(nèi)容中間的位置后,你是可以繼續(xù)輸入的這種輸入讓人很苦惱因?yàn)楫?dāng)你輸入后你的光標(biāo)會移動到最后,并且限制你繼續(xù)輸入,但是你剛剛輸入的內(nèi)榮卻保留在了文本中間,這很不符合要求.
因此在這里采用代理可以很好的實(shí)現(xiàn)我們想要的效果,僅僅幾行代碼希望給你帶來幫助.
 - (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string {    if (textField == self.liveThemeTextField) {  //這里的if時(shí)候?yàn)榱双@取刪除操作,如果沒有次if會造成當(dāng)達(dá)到字?jǐn)?shù)限制后刪除鍵也不能使用的后果.    if (range.length == 1 && string.length == 0) {      return YES;    }    //so easy    else if (self.liveThemeTextField.text.length >= 30) {      self.liveThemeTextField.text = [textField.text substringToIndex:30];      return NO;    }  }  return YES;}以上就是本文的全部內(nèi)容,希望對大家的學(xué)習(xí)有所幫助,也希望大家多多支持VEVB武林網(wǎng)。
新聞熱點(diǎn)
疑難解答
圖片精選