由于编码原因,在文本框中输入“Emoji”表情的时候后台返回异常数据。所以在前台发送请求的时候直接过滤掉。
直接上代码和使用方法:UITextField和这个一样,在代理方法中添加下面的方法。这里不一一写了。
UITextView中代理方法:
- (BOOL)textView:(UITextView *)textView shouldChangeTextInRange:(NSRange)range replacementText:(NSString *)text
{
//这个只是在键盘为Emoji的时候禁止使用
if ([[[UITextInputMode currentInputMode] primaryLanguage] isEqualToString:@"emoji"]) {
return NO;
}
//补充我们的项目禁止回车换行
if ( [text isEqualToString:@"\n"]){ //判断输入的字是否是回车,即按下return UITextView禁止换行
return NO; //这里返回NO,就代表return键值失效,即页面上按下return,不会出现换行,如果为yes,则输入页面会换行
}
return YES;
}
那么还有一种情况是键盘输入文字后,联想到表情解决方法:
-(void)textViewDidChange:(UITextView *)textView
{
//Emoji表情输入后是两个字符,所以采用这个方法,如果检测到输入了表情,那么直接删除表情
if ([self stringContainsEmoji:textView.text]) {
textView.text = [textView.text substringToIndex:textView.text.length-2];
}
}
注意:此处存在一个BUG,-2只针对表情,但是如果输入“得”等文字联想到的表情是3个字符,所以暂时没发判断,使用的时候请注意。得到的文字为空了。
//判断条件
- (BOOL)stringContainsEmoji:(NSString *)string
{
__block BOOL returnValue = NO;
[string enumerateSubstringsInRange:NSMakeRange(0, [string length])
options:NSStringEnumerationByComposedCharacterSequences
usingBlock:^(NSString *substring, NSRange substringRange, NSRange enclosingRange, BOOL *stop) {
const unichar hs = [substring characterAtIndex:0];
if (0xd800 <= hs && hs <= 0xdbff) {
if (substring.length > 1) {
const unichar ls = [substring characterAtIndex:1];
const int uc = ((hs - 0xd800) * 0x400) + (ls - 0xdc00) + 0x10000;
if (0x1d000 <= uc && uc <= 0x1f77f) {
returnValue = YES;
}
}
} else if (substring.length > 1) {
const unichar ls = [substring characterAtIndex:1];
if (ls == 0x20e3) {
returnValue = YES;
}
} else {
if (0x2100 <= hs && hs <= 0x27ff) {
returnValue = YES;
} else if (0x2B05 <= hs && hs <= 0x2b07) {
returnValue = YES;
} else if (0x2934 <= hs && hs <= 0x2935) {
returnValue = YES;
} else if (0x3297 <= hs && hs <= 0x3299) {
returnValue = YES;
} else if (hs == 0xa9 || hs == 0xae || hs == 0x303d || hs == 0x3030 || hs == 0x2b55 || hs == 0x2b1c || hs == 0x2b1b || hs == 0x2b50) {
returnValue = YES;
}
}
}];
return returnValue;
}