iOS 限制TextField輸入長度(標准)


iOS 限制TextField輸入長度(標准)


網上有很多限制textField輸入長度方法,但是我覺得都不是很完美,准確來說可以說是不符合實際開發的要求,因此在這里整理一下textField限制輸入長度的方法.
我所采用的並不是監聽方法而是最不同的代理實現方法,為什么不使用監聽呢???
當你看到這篇文章很有可能視是為一件事所苦惱那就是使用監聽限制輸入長度后不能夠完美的控制輸入內容.
舉一個簡單的例子:
你要限制輸入長度為30個字符,當你輸入30個字符后監聽的確可以很好的控制不讓你繼續輸入,但是問題也隨之而來,當你把光標移動到輸入內容中間的位置后,你是可以繼續輸入的這種輸入讓人很苦惱因為當你輸入后你的光標會移動到最后,並且限制你繼續輸入,但是你剛剛輸入的內榮卻保留在了文本中間,這很不符合要求.
因此在這里采用代理可以很好的實現我們想要的效果,僅僅幾行代碼希望給你帶來幫助.

- (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string {
    
    if (textField == self.liveThemeTextField) {
    //這里的if時候為了獲取刪除操作,如果沒有次if會造成當達到字數限制后刪除鍵也不能使用的后果.
        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;
}

遇到問題不要慌,靜下心來慢慢想.
by:旭寶愛吃魚


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM