简体   繁体   中英

How to validate textField in swift using SkyFloatingLabelTextField

I am using SkyFloatingLabeltextField for textfield. I want to check all the textfields are valid then I want to call next viewController.So please tell me how to check func textField(_ textField: UITextField, shouldChangeCharactersIn range: NSRange, replacementString string: String) -> Bool {}

is true or not??? Below is my code

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


    if let text = username.text {

        let message = Comman.matches(for: "[a-zA-Z]+[0-9a-zA-Z._%+-]+[a-zA-Z0-9]+@[a-zA-Z0-9-]+\\.[a-zA-Z]{1,6}", in: text)

        print(message.count);
        print(message)
        if let floatingLabelTextField = username as? SkyFloatingLabelTextField {
            if(message.count != 1) {
                floatingLabelTextField.errorMessage = "Please enter valid email id"
            }
            else {
                // The error message will only disappear when we reset it to nil or empty string
                floatingLabelTextField.errorMessage = ""
            }

        }
    }

    if let text = password.text {

        let message = Comman.matches(for: "^(?=.*[a-z])(?=.*[A-Z])(?=.*[!@#$%^&])(?=.*\\d).{8,16}$", in: text)

        if let floatingLabelTextField = password as? SkyFloatingLabelTextField {
            if(message.count != 1) {
                floatingLabelTextField.errorMessage = "Please enter valid Password"
            }
            else {
                // The error message will only disappear when we reset it to nil or empty string
                floatingLabelTextField.errorMessage = ""
            }

        }
    }

    if let text = firstName.text {
        let characterset = CharacterSet(charactersIn: "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLKMNOPQRSTUVWXYZ0123456789")

        if let floatingLabelTextField = firstName as? SkyFloatingLabelTextField {
        if text.rangeOfCharacter(from: characterset.inverted) != nil {
            floatingLabelTextField.errorMessage = "Please enter valid Name"
        }
        else {
                // The error message will only disappear when we reset it to nil or empty string
                floatingLabelTextField.errorMessage = ""
            }

        }
    }

    if let text = lastName.text {
        let characterset = CharacterSet(charactersIn: "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLKMNOPQRSTUVWXYZ0123456789")

        if let floatingLabelTextField = lastName as? SkyFloatingLabelTextField {
            if text.rangeOfCharacter(from: characterset.inverted) != nil {
                floatingLabelTextField.errorMessage = "Please enter valid Name"
            }
            else {
                // The error message will only disappear when we reset it to nil or empty string
                floatingLabelTextField.errorMessage = ""
            }

        }
    }
    if let text = mobileNumber.text {
        let characterset = CharacterSet(charactersIn: "abcdefghijklmnopqrstuvwxyzABCDEFGHIJKLKMNOPQRSTUVWXYZ0123456789")

        if let floatingLabelTextField = mobileNumber as? SkyFloatingLabelTextField {
            if text.rangeOfCharacter(from: characterset.inverted) != nil {
                floatingLabelTextField.errorMessage = "Please enter valid Mobile number"
            }
            else {
                // The error message will only disappear when we reset it to nil or empty string
                floatingLabelTextField.errorMessage = ""
            }

        }
    }

    return true
}

And my button like as

    @IBAction func signUpButtonPressed(_ sender: Any) {  if username.text == "" {
         if let floatingLabelTextField = username as? SkyFloatingLabelTextField {
             floatingLabelTextField.errorMessage = "Please enter UserName"
        }
    }
    if password.text == "" {
        if let floatingLabelTextField = password as? SkyFloatingLabelTextField {
            floatingLabelTextField.errorMessage = "Please enter Password"
        }
    }

    if firstName.text == "" {
        if let floatingLabelTextField = firstName as? SkyFloatingLabelTextField {
            floatingLabelTextField.errorMessage = "Please enter First Name"
        }
    }
    if lastName.text == "" {
        if let floatingLabelTextField = lastName as? SkyFloatingLabelTextField {
            floatingLabelTextField.errorMessage = "Please enter Last Name"
        }
    }
    if mobileNumber.text == "" {
        if let floatingLabelTextField = mobileNumber as? SkyFloatingLabelTextField {
            floatingLabelTextField.errorMessage = "Please enter Mobile Number"
        }
    }

}

So how to handle it when it is valid????

You need to implement the delegate of UITextfield in that case :

if you want to check the each character input and want control over the text input use following method :

func textField(_ textField: UITextField, shouldChangeCharactersIn range: NSRange, replacementString string: String) -> Bool {
    if textField == newPasswordTextField {
        let newString = NSString(string: textField.text!).replacingCharacters(in: range, with: string)
        let existOrNotNumber  = checkTextNumber(text: newString)
        let existOrNotSpecialCharacter  = checkSpecialCharacter(text: newString)
        let existOrNotCapitalCharacter = CapitalLetter(text: newString)
        let existOrNotlwerCharacter = lowerCaseLetter(text: newString)
        let usernameSameOrNot = checkUserName(text: newString )

        textField.text = newString;

        if existOrNotNumber {
            numericDigitLabel.textColor = kGreenColor
        }else{
            numericDigitLabel.textColor = UIColor.red
        }
        if existOrNotSpecialCharacter {
            specialCharacterLabel.textColor = kGreenColor
        }else{
            specialCharacterLabel.textColor = UIColor.red
        }
        if existOrNotCapitalCharacter{
            uppercaseCharacterLabel.textColor = kGreenColor
        }else{
            uppercaseCharacterLabel.textColor = UIColor.red
        }
        if existOrNotlwerCharacter{
            lowercaseCharacterLabel.textColor = kGreenColor
        }else{
            lowercaseCharacterLabel.textColor = UIColor.red
        }
        if (newString.characters.count) >= 8 && (newString.characters.count) <= 50 {
            minimumEightCharacterLabel.textColor = kGreenColor
        }else{
            minimumEightCharacterLabel.textColor = UIColor.red
        }
        if usernameSameOrNot{
         userNameCannotBePasslabel.textColor = kGreenColor
        }else{
         userNameCannotBePasslabel.textColor = UIColor.red
        }
        return false
    }
    return true
}

you can check every text validation here . for validation i have created this generic function to validate .

// MARK: - Validation for  Textfield

func isValidAllFields() -> Bool {
    var isValid = true
    var errorMessage : String = ""
    let showAndReturn : () -> Bool = { Void -> Bool in
        AppUtility.showAlert(message: errorMessage, isSuccess: false)
        return isValid
    }

    let showAndReturnWithoutToast : () -> Bool = { Void -> Bool in
        return isValid
    }

    if (oldPasswordTextField.text ?? "").isEmpty || (oldPasswordTextField.text?.trimmingCharacters(in: .whitespaces).characters.count)! == 0  {
        isValid = false
        errorMessage = kOldPasswordEmptyMessage
        return showAndReturn()
    }

    if (newPasswordTextField.text ?? "").isEmpty || (newPasswordTextField.text?.trimmingCharacters(in: .whitespaces).characters.count)! == 0  {
        isValid = false
        errorMessage = kNewPasswordEmptyMessage
        return showAndReturn()
    }

    if (confirmPasswordTextField.text ?? "").isEmpty || (confirmPasswordTextField.text?.trimmingCharacters(in: .whitespaces).characters.count)! == 0  {
        isValid = false
        errorMessage = kConfirmPasswordEmptyMessage
        return showAndReturn()
    }

    if oldPasswordTextField.text != UserDefaults.standard.object(forKey: kOldPassword) as? String {
        isValid = false
        errorMessage = kCorrectOldPasswordMessage
        return showAndReturn()
    }

    if  (newPasswordTextField.text?.characters.count)! < 8 || (newPasswordTextField.text?.characters.count)! > 50 {
        isValid = false
        return showAndReturnWithoutToast()
        // errorMessage = "New password should not be less than 8 characters and more than 50 characters"
    }

    if !checkTextNumber(text: newPasswordTextField.text!) {
         isValid = false
         return showAndReturnWithoutToast()
         // errorMessage = "New password must contain at least 1 Numeric digit"
    }

    if !checkSpecialCharacter(text: newPasswordTextField.text!) {
        isValid = false
        return showAndReturnWithoutToast()
        // errorMessage = "New password must contain at least 1 special character"
    }

    if !CapitalLetter(text: newPasswordTextField.text!) {
        isValid = false
        return showAndReturnWithoutToast()
        //errorMessage = "New password must contain at least 1 Upper case character"
    }

    if !lowerCaseLetter(text: newPasswordTextField.text!) {
        isValid = false
        return showAndReturnWithoutToast()
        // errorMessage = "New password must contain at least 1 Lower case character"
    }

    if !checkUserName(text: newPasswordTextField.text!) {
        isValid = false
        return showAndReturnWithoutToast()
    }

    if confirmPasswordTextField.text != newPasswordTextField.text{
        isValid = false
        errorMessage = kNewPassAndCofirmSameMessage
        return showAndReturn()
    }
    return isValid
}

on Button click just check if isValid() , if it return true then you allow it to pass to the next view controller

If you want perform checking while typing, you can use the delegate method to perform the checking:

func textField(_ textField: UITextField, shouldChangeCharactersIn range: NSRange, replacementString string: String) -> Bool {
    let text = NSString(string: textField.text!).replacingCharacters(in: range, with: string)
    // Perform validation of the `text`
    if valid {
        return true
    } else {
        return false
    }
}

Or if you want to perform the checking after all the fields are filled, you can just check for the text by textField.text .

The technical post webpages of this site follow the CC BY-SA 4.0 protocol. If you need to reprint, please indicate the site URL or the original address.Any question please contact:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM