Подтвердить что ты не робот

Разрешить только буквенно-цифровые символы для UITextField

Как я могу позволить вводить только буквенно-цифровые символы в iOS UITextField?

4b9b3361

Ответ 1

Используйте метод UITextFieldDelegate -textField:shouldChangeCharactersInRange:replacementString: с NSCharacterSet, содержащий обратный символ, который вы хотите разрешить. Например:

// in -init, -initWithNibName:bundle:, or similar
NSCharacterSet *blockedCharacters = [[[NSCharacterSet alphanumericCharacterSet] invertedSet] retain];

- (BOOL)textField:(UITextField *)field shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)characters
{
    return ([characters rangeOfCharacterFromSet:blockedCharacters].location == NSNotFound);
}

// in -dealloc
[blockedCharacters release];

Обратите внимание, что вам нужно объявить, что ваш класс реализует протокол (т.е. @interface MyClass : SomeSuperclass <UITextFieldDelegate>) и задает текстовые поля delegate экземпляру вашего класса.

Ответ 2

Вот как я это делаю:

// Define some constants:
#define ALPHA                   @"ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz"
#define NUMERIC                 @"1234567890"
#define ALPHA_NUMERIC           ALPHA NUMERIC

// Make sure you are the text fields 'delegate', then this will get called before text gets changed.
- (BOOL)textField:(UITextField *)textField shouldChangeCharactersInRange:(NSRange)range replacementString:(NSString *)string {

    // This will be the character set of characters I do not want in my text field.  Then if the replacement string contains any of the characters, return NO so that the text does not change.
    NSCharacterSet *unacceptedInput = nil;

    // I have 4 types of textFields in my view, each one needs to deny a specific set of characters:
    if (textField == emailField) {
        //  Validating an email address doesnt work 100% yet, but I am working on it....  The rest work great!
        if ([[textField.text componentsSeparatedByString:@"@"] count] > 1) {
            unacceptedInput = [[NSCharacterSet characterSetWithCharactersInString:[ALPHA_NUMERIC stringByAppendingString:@".-"]] invertedSet];
        } else {
            unacceptedInput = [[NSCharacterSet characterSetWithCharactersInString:[ALPHA_NUMERIC stringByAppendingString:@".!#$%&'*+-/=?^_`{|}[email protected]"]] invertedSet];
        }
    } else if (textField == phoneField) {
        unacceptedInput = [[NSCharacterSet characterSetWithCharactersInString:NUMERIC] invertedSet];
    } else if (textField == fNameField || textField == lNameField) {
        unacceptedInput = [[NSCharacterSet characterSetWithCharactersInString:ALPHA] invertedSet];
    } else {
        unacceptedInput = [[NSCharacterSet illegalCharacterSet] invertedSet];
    }

    // If there are any characters that I do not want in the text field, return NO.
    return ([[string componentsSeparatedByCharactersInSet:unacceptedInput] count] <= 1);
}

Проверьте UITextFieldDelegate Reference.

Ответ 3

Я нашел простой и эффективный ответ и хочу поделиться:

подключите UITextField для события EditingChanged к следующему IBAction

-(IBAction) editingChanged:(UITextField*)sender
{    
    if (sender == yourTextField)
    {
        // allow only alphanumeric chars
        NSString* newStr = [sender.text stringByTrimmingCharactersInSet:[[NSCharacterSet alphanumericCharacterSet] invertedSet]];

        if ([newStr length] < [sender.text length])
        {
            sender.text = newStr;
        }
    }
}

Ответ 4

версия Swift 3

Принимаемый в настоящее время подход к ответам:

func textField(_ textField: UITextField, shouldChangeCharactersIn range: NSRange, replacementString string: String) -> Bool {

    // Get invalid characters
    let invalidChars = NSCharacterSet.alphanumerics.inverted

    // Attempt to find the range of invalid characters in the input string. This returns an optional.
    let range = string.rangeOfCharacter(from: invalidChars)

    if range != nil {
        // We have found an invalid character, don't allow the change
        return false
    } else {
        // No invalid character, allow the change
        return true
    }
}

Другой одинаково функциональный подход:

func textField(_ textField: UITextField, shouldChangeCharactersIn range: NSRange, replacementString string: String) -> Bool {

    // Get invalid characters
    let invalidChars = NSCharacterSet.alphanumerics.inverted

    // Make new string with invalid characters trimmed
    let newString = string.trimmingCharacters(in: invalidChars)

    if newString.characters.count < string.characters.count {
        // If there are less characters than we started with after trimming
        // this means there was an invalid character in the input. 
        // Don't let the change go through
        return false
    } else {
        // Otherwise let the change go through
        return true
    }

}

Ответ 5

Для Swift: Подключите UITextField для события EditingChanged к следующему IBAction:

@IBAction func ActionChangeTextPassport(sender:UITextField){
    if sender == txtPassportNum{
        let newStr = sender.text?.stringByTrimmingCharactersInSet(NSCharacterSet.alphanumericCharacterSet().invertedSet)
        if newStr?.characters.count < sender.text?.characters.count{
            sender.text = newStr
        }
    }
}

Ответ 6

Режим RegEx в Swift:

func textField(_ textField: UITextField, shouldChangeCharactersIn range: NSRange, replacementString string: String) -> Bool {
     if string.isEmpty {
         return true
     }
     let alphaNumericRegEx = "[a-zA-Z0-9]"
     let predicate = NSPredicate(format:"SELF MATCHES %@", alphaNumericRegEx)
     return predicate.evaluate(with: string)
}

Ответ 7

Вам нужно будет использовать методы textField delegate и использовать методы textFieldDidBeginEditing, shouldChangeCharactersInRange и textFieldDidEndEditing для проверки символов.

Пожалуйста, обратитесь к этой ссылке для документации.