您好,登录后才能下订单哦!
这篇文章将为大家详细讲解有关iOS开发中如何实现苹果输入手机号变用户的名字,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。
1.文本替换
遇到这种事情肯定去百度啊,发现还真有人和我遇到相同的情况,原来这个用户在设置-》通用-》键盘-》文本替换把自己的手机号设置自己的名字了,这样只要在UITextField中输入自己的手机号,输入完就会变成自己的名字,出现上图的情况。
其实这个功能还是满好玩的,不过用户要是把自己的手机号设置文本替换了,那么在APP里注册就会出现问题了。当时我就想是不是微信也这样啊,
看来微信已经解决了这个问题,他手机号中间加了两个空格,而文本替换是不允许加空格的,所以可以正常完成登录。这里不得不为微信的工程师们点赞啊!不过淘宝更厉害,没有加空格,也没有进行文本替换,真是厉害啊。我又去看了其他App,基本上都是用空格来防止文本替换的,但是也有一些注册登录不了的,有兴趣的可以去尝试。
2.用空格防止文本替换
#pragma mark - UITextFieldDelegate -(BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string { if (textField == _txtUserName) { // 12312345678-> 123 1234 5678 if (range.location == 3 || range.location == 8) { textField.text = [textField.text stringByAppendingString:@" "]; } // 手机号最多输13位 包含两个空格,防止文本替换 if(range.location >= 13){ return NO; } } return YES; }
这样就成功的防止文本替换了,因为文本替换不能包含空格。但是我又发现删除不了了,就是当删除到空格的时候就不能继续删除了。难道是数字键盘里不能删除空格???后来我分析代码发现当我删除到空格的时候,就会自动帮我在后面再加上一个空格,这样我就永远把空格删除不了了。所以我要区分只有在输入的时候添加空格,删除到123 1234 5678的5时,自动把5前面的空格去掉。
3.区分输入和删除
当UITextField删除的时候执行- (void)deleteBackward
;方法,这个方法在UIKeyInput协议中。那这就好办了,自定义UITextField的,重写- (void)deleteBackward
;,这个方法一执行,就发通知,或者走代理,都可以。后来我发现这有点麻烦,我还要自定义,发通知/代理,太麻烦了。所以我就想通过监测UITextField的location
来区分输入或删除。
#pragma mark - UITextFieldDelegate -(BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string { if (textField == _txtUserName) { // 删除 if (_lastLocation > range.location) { if (range.location == 9 || range.location == 4) { // 删除到空格后一位的时候,自动把空格也去掉 textField.text = [textField.text substringToIndex:range.location]; } _lastLocation = range.location - 1; return YES; }else { // 输入 if (range.location == 3 || range.location == 8) { textField.text = [textField.text stringByAppendingString:@" "]; } } _lastLocation = range.location; // 手机号最多输13位 包含两个空格,防止文本替换 if(range.location >= 13){ return NO; } } return YES; }
其实用户一多,对开发者来说成长会非常快,因为什么情况都会遇到,我们就在解决问题中成长。
关于“iOS开发中如何实现苹果输入手机号变用户的名字”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。