SwiftUI – SecureField

The SecureField in SwiftUI is a specialised text field designed to securely accept sensitive information such as passwords. When users type into a SecureField, the input is masked with dots or asterisks to prevent it from being visible on the screen. This is essential for creating login forms or any feature that involves sensitive data input.

In this SwiftUI tutorial, we will cover the basic usage of SecureField with examples to demonstrate how to implement it effectively in your SwiftUI app.


Basic Syntax of SecureField

The basic syntax for creating a SecureField is:

</>
Copy
SecureField("Placeholder Text", text: $password)

Here:

  • "Placeholder Text": The placeholder text displayed when the field is empty.
  • $password: A binding variable that holds the user’s input securely.

To use SecureField, you need a @State variable to bind the input to the view.


Examples

Let’s explore some basic examples to understand how to use SecureField in SwiftUI.


Example 1: Simple SecureField

Here’s how to create a simple password field:

Code Example:

</>
Copy
import SwiftUI

struct ContentView: View {
    @State private var password: String = ""
    
    var body: some View {
        VStack {
            SecureField("Enter your password", text: $password)
                .padding()
                .textFieldStyle(RoundedBorderTextFieldStyle())
            
            Text("Your password: \(password)")
                .padding()
        }
        .frame(maxWidth: .infinity, maxHeight: .infinity, alignment: .top)
        .padding()
    }
}

Explanation:

  • The SecureField accepts input and stores it in the @State variable password.
  • The placeholder text “Enter your password” appears when the field is empty.
  • .textFieldStyle(RoundedBorderTextFieldStyle()) applies a rounded border to the field for better styling.
  • The Text below displays the entered password (for demonstration purposes). In a real application, you would avoid displaying passwords directly.

Xcode Screenshot:

SwiftUI - SecureField - Basic Example where user enters password, and the same is displayed (for learning)

Output:

Result: A secure input field with a rounded border appears, allowing users to type a password that is masked with dots or asterisks.


Example 2: SecureField with Action on Pressing Return Key

You can perform an action when the user presses the return key in the SecureField. Here’s how:

Code Example:

</>
Copy
import SwiftUI

struct ContentView: View {
    @State private var password: String = ""
    @State private var message: String = "Enter your password."
    
    var body: some View {
        VStack {
            SecureField("Password", text: $password, onCommit: {
                validatePassword()
            })
            .padding()
            .textFieldStyle(RoundedBorderTextFieldStyle())
            
            Text(message)
                .padding()
        }
        .padding()
    }
    
    func validatePassword() {
        if password.isEmpty {
            message = "Password cannot be empty."
        } else {
            message = "Password accepted!"
        }
    }
}

Explanation:

  • The onCommit parameter triggers the validatePassword function when the user presses the return key.
  • The validation checks if the password is empty and updates the message accordingly.

Output:

Result: When the user presses the return key, the app validates the input and displays an appropriate message.


Conclusion

The SecureField in SwiftUI is an essential component for creating secure text inputs such as password fields. With its simple implementation and flexibility, you can easily integrate it into your app to enhance user privacy and security.