IOS开发问题解决之限制UITextField输入特定位数小数时,Done按钮失效

本文详细阐述了如何通过重写UITextField的delegate方法限制输入为一位小数,并解决了“Done”按钮失效的问题。通过代码优化,不仅实现了功能需求,还避免了事件失效,提供了一个更完整的解决方案。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

问题描述

要求是限制UITextField只能输入一位小数。我的方法是重写delegate的textField:shouldChangeCharactersInRange:replacementString:函数。自己写的代码如下:

-(BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string{
    
    isHasRadixPoint = YES;
    NSString *existText = textField.text;
    if ([existText rangeOfString:@"."].location == NSNotFound) {
        isHasRadixPoint = NO;
    }
    if (string.length > 0) {
        unichar newChar = [string characterAtIndex:0];
        if ((newChar >= '0' && newChar <= '9') || newChar == '.' ) {
            if (newChar == '.') {
                if (isHasRadixPoint) 
                    return NO;
                else 
                    return YES;                
            }else {
                if (isHasRadixPoint) {
                    NSRange ran = [existText rangeOfString:@"."];
                    int radixPointCount = range.location - ran.location;
                    if (radixPointCount <= RadixPointNum) return YES;
                    else return NO;
                } else 
                    return YES;
            }
            
        }else {
            return NO;
        }
        
    }else {
        return YES;
    }
}

写完测试,这时问题来了。键盘上的"Done"按钮失效了。上面代码中的RandixPointNum是在文件最上边部分定义的宏,代表小数点位数。

解决方法

“Done”按钮其实就是字符“\n”,由于上面的代码将其过滤了,导致了其事件失效。修改后代码如下,注意有注释的那行:

-(BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string{
    
    isHasRadixPoint = YES;
    NSString *existText = textField.text;
    if ([existText rangeOfString:@"."].location == NSNotFound) {
        isHasRadixPoint = NO;
    }
    if (string.length > 0) {
        unichar newChar = [string characterAtIndex:0];
        if ((newChar >= '0' && newChar <= '9') || newChar == '.' ) {
            if (newChar == '.') {
                if (isHasRadixPoint) 
                    return NO;
                else 
                    return YES;                
            }else {
                if (isHasRadixPoint) {
                    NSRange ran = [existText rangeOfString:@"."];
                    int radixPointCount = range.location - ran.location;
                    if (radixPointCount <= RadixPointNum) return YES;
                    else return NO;
                } else 
                    return YES;
            }
            
        }else {
            if ( newChar == '\n') return YES;       // 这句非常重要:不然将导致“Done”按钮失效
            return NO;
        }
        
    }else {
        return YES;
    }
}

问题总结

虽然同样也完成了任务,总觉得这样写不是特别好,不知还有没有好的方法。


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值