前言
前兩周我們發(fā)了一個小集「iOS 自帶九宮格拼音鍵盤與 Emoji 表情之間的坑」,介紹了如何解決由于輸入框限制 Emoji 表情的輸入導致中文拼音也無法輸入的問題。
后面我們又有了新需求:對輸入框已輸入的文本字數(shù)進行實時統(tǒng)計,并在界面上顯示剩余字數(shù),且不能讓所輸入的文本超過最大限制長度。但這個簡單的功能仍然有不少小坑。
在上一個小集中,我們講到,對于 iOS 系統(tǒng)自帶的鍵盤,有時候它在輸入框中填入的是占位字符(已被高亮選中起來),等用戶選中鍵盤上的候選詞時,再替換為真正輸入的字符,如下:
這會帶來一個問題:比如輸入框限定最多只能輸入 10 位,當已經(jīng)輸入 9 個漢字的時候,使用系統(tǒng)拼音鍵盤則第 10 個字的拼音就打不了(因為剩余的 1 位無法輸入完整的拼音)。
iOS輸入框的字數(shù)統(tǒng)計/最大長度限制
怎么辦呢?上面提到,輸入框中的拼音會被高亮選中起來,所以我們可以根據(jù) UITextField 的 markedTextRange 屬性判斷是否存在高亮字符,如果有則不進行字數(shù)統(tǒng)計和字符串截斷操作。我們可以通過監(jiān)聽 UIControlEventEditingChanged 事件來對輸入框內(nèi)容的變化進行相應處理,如下:
[self.textField addTarget:self action:@selector(textFieldDidChanged:) forControlEvents:UIControlEventEditingChanged];
- (void)textFieldDidChanged:(UITextField *)textField { // 判斷是否存在高亮字符,如果有,則不進行字數(shù)統(tǒng)計和字符串截斷 UITextRange *selectedRange = textField.markedTextRange; UITextPosition *position = [textField positionFromPosition:selectedRange.start offset:0]; if (position) { return; } // maxWowdLimit 為 0,不限制字數(shù) if (self.maxWowdLimit == 0) { return; } // 判斷是否超過最大字數(shù)限制,如果超過就截斷 if (textField.text.length > self.maxWowdLimit) { textField.text = [textField.text substringToIndex:self.maxWowdLimit]; } // 剩余字數(shù)顯示 UI 更新}
對于 UITextView 的處理也是類似的。
另外,對于“字數(shù)”的定義是很多種理解:在 Objective-C 中字符串 NSString 的長度 length,對于一個中文漢字和一個英文字母都是 1;但如果我們要按字節(jié)來統(tǒng)計和限制,同一字符的在不同編碼編碼下所占的字節(jié)數(shù)也是不同的;另外有時我們要統(tǒng)計的是所輸入文本的單詞個數(shù),而不是字符串的長度,所以我們需要根據(jù)不同的使用場景進行分析。
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對VEVB武林網(wǎng)的支持。
新聞熱點
疑難解答
圖片精選