如何更好地限制一個UITextField的輸入長度

要限制一個UITextField的輸入字數(shù)(參考鏈接)捏膨,首先想到的應(yīng)該是通過

UITextFieldDelegate

的代理方法來限制:

- (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string;//returnNO to not change text

比如要設(shè)置字數(shù)限制為20:

- (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string{if(textField == self.titleField) {if(textField.length > 20)returnNO;? ? }returnYES;}

但是這樣的限制簡單粗暴,可能會影響用戶正常邏輯下的輸入,比如輸入了20個字符后芥驳,要退格回刪字符半哟。

這時候我們可能會考慮“Detect backspace in UITextField”绘证,比如簡單地判斷replacementString的長度是否為0撵割。

接著我們可能還會遇到用戶已經(jīng)輸入20個字符了,這時候繼續(xù)輸入---不過是選擇了部分文本進行替換-----無法進行了跑杭,這也妨礙了用戶的正常操作铆帽,所以限制的代碼版本可能會演進為:

#pragma mark - UITextFieldDelegate- (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string{if(textField == self.titleField) {if(string.length == 0)returnYES;? ? ? ? NSInteger existedLength = textField.text.length;? ? ? ? NSInteger selectedLength = range.length;? ? ? ? NSInteger replaceLength = string.length;if(existedLength - selectedLength + replaceLength > 20) {returnNO;? ? ? ? }? ? }returnYES;}

到這里可能會覺得基本大功告成了,但是當你輸入19個字符后德谅,第20個字符以中文漢字的形式繼續(xù)輸入爹橱,那么系統(tǒng)會在鍵盤上方提供后續(xù)的一系列聯(lián)想詞,你會發(fā)現(xiàn)通過這種方式可以連續(xù)選字輸入從而突破20個字符的限制窄做。WTF

到了這里愧驱,我們可能會希望有個類似

- (void)textFieldDidChange:(UITextField *)textField

的回調(diào)方法,但可惜沒有椭盏。

當然组砚,我們還可以通過

- (void)textFieldDidEndEditing:(UITextField *)textField;

回調(diào)方法在結(jié)束編輯的時候把文本截斷,雖然在用戶體驗上會有點突兀掏颊。

不過當我們點進去UITextField.h頭文件里尋覓上述回調(diào)方法而不得時糟红,可能會發(fā)現(xiàn)最下面有這么個消息通知名稱:

UIKIT_EXTERN NSString *constUITextFieldTextDidChangeNotification;

不過,監(jiān)聽消息還要記得解除監(jiān)聽,通常我還習(xí)慣把監(jiān)聽消息的代碼統(tǒng)一放在一個方法中盆偿,看起來有點“大動干戈”掩蛤。

所幸的是UITextField本身提供了相應(yīng)的事件監(jiān)聽

[textField addTarget:self action:@selector(textFieldDidChange:) forControlEvents:UIControlEventEditingChanged];

這樣就可以更好地限制輸入長度:

- (void)textFieldDidChange:(UITextField *)textField{if(textField == self.titleField) {if(textField.text.length > 20) {? ? ? ? ? ? textField.text = [textField.text substringToIndex:20];? ? ? ? }? ? }}

轉(zhuǎn)載:http://blog.csdn.net/jasonblog/article/details/23771117

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市陈肛,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌兄裂,老刑警劉巖句旱,帶你破解...
    沈念sama閱讀 206,126評論 6 481
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異晰奖,居然都是意外死亡谈撒,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 88,254評論 2 382
  • 文/潘曉璐 我一進店門匾南,熙熙樓的掌柜王于貴愁眉苦臉地迎上來啃匿,“玉大人,你說我怎么就攤上這事蛆楞∷萜梗” “怎么了?”我有些...
    開封第一講書人閱讀 152,445評論 0 341
  • 文/不壞的土叔 我叫張陵豹爹,是天一觀的道長裆悄。 經(jīng)常有香客問我,道長臂聋,這世上最難降的妖魔是什么光稼? 我笑而不...
    開封第一講書人閱讀 55,185評論 1 278
  • 正文 為了忘掉前任,我火速辦了婚禮孩等,結(jié)果婚禮上艾君,老公的妹妹穿的比我還像新娘。我一直安慰自己肄方,他們只是感情好冰垄,可當我...
    茶點故事閱讀 64,178評論 5 371
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著权她,像睡著了一般播演。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上伴奥,一...
    開封第一講書人閱讀 48,970評論 1 284
  • 那天写烤,我揣著相機與錄音,去河邊找鬼拾徙。 笑死洲炊,一個胖子當著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播暂衡,決...
    沈念sama閱讀 38,276評論 3 399
  • 文/蒼蘭香墨 我猛地睜開眼询微,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了狂巢?” 一聲冷哼從身側(cè)響起撑毛,我...
    開封第一講書人閱讀 36,927評論 0 259
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎唧领,沒想到半個月后藻雌,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 43,400評論 1 300
  • 正文 獨居荒郊野嶺守林人離奇死亡斩个,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 35,883評論 2 323
  • 正文 我和宋清朗相戀三年胯杭,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片受啥。...
    茶點故事閱讀 37,997評論 1 333
  • 序言:一個原本活蹦亂跳的男人離奇死亡做个,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出滚局,到底是詐尸還是另有隱情居暖,我是刑警寧澤,帶...
    沈念sama閱讀 33,646評論 4 322
  • 正文 年R本政府宣布藤肢,位于F島的核電站膝但,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏谤草。R本人自食惡果不足惜跟束,卻給世界環(huán)境...
    茶點故事閱讀 39,213評論 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望丑孩。 院中可真熱鬧冀宴,春花似錦、人聲如沸温学。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,204評論 0 19
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽仗岖。三九已至逃延,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間轧拄,已是汗流浹背揽祥。 一陣腳步聲響...
    開封第一講書人閱讀 31,423評論 1 260
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留檩电,地道東北人拄丰。 一個月前我還...
    沈念sama閱讀 45,423評論 2 352
  • 正文 我出身青樓府树,卻偏偏與公主長得像,于是被迫代替她去往敵國和親料按。 傳聞我的和親對象是個殘疾皇子奄侠,可洞房花燭夜當晚...
    茶點故事閱讀 42,722評論 2 345

推薦閱讀更多精彩內(nèi)容