CodexBloom - Programming Q&A Platform

SwiftUI: Binding not updating on TextField when using a custom binding in iOS 17

👀 Views: 18 đŸ’Ŧ Answers: 1 📅 Created: 2025-06-12
swift swiftui bindings Swift

This might be a silly question, but I tried several approaches but none seem to work. I'm relatively new to this, so bear with me... I'm facing an issue where my `TextField` is not updating its displayed value when using a custom binding in my SwiftUI app. I have a view model with a property that uses a custom setter to manipulate the input before storing it, but the `TextField` doesn't seem to reflect the changes correctly. Here's a simplified version of my code: ```swift import SwiftUI class ViewModel: ObservableObject { @Published var input: String = "" var customInput: String { get { input } set { input = newValue.trimmingCharacters(in: .whitespaces) } } } struct ContentView: View { @ObservedObject var viewModel = ViewModel() var body: some View { VStack { TextField("Enter text", text: Binding( get: { viewModel.customInput }, set: { viewModel.customInput = $0 } )) .textFieldStyle(RoundedBorderTextFieldStyle()) .padding() Text("Current Value: \(viewModel.input)") } .padding() } } ``` Whenever I type in the `TextField`, the `input` property in the `ViewModel` is updated, but the displayed value in the `TextField` doesn't reflect any changes until the field resigns first responder status. I expected the `TextField` to show the trimmed value instantly. I've tried using a standard binding without the custom setter, and it works as expected, but I need the trimming functionality to ensure that the input is clean before processing it. Is there a better way to handle this, or am I missing something specific to bindings in SwiftUI? Any insights would be greatly appreciated! Thanks in advance!