網(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)
疑難解答
圖片精選