У меня есть приложение Swiftui с жизненным циклом приложения Swiftui. Я пытаюсь настроить стандартный способ добавления
typling debround в Textfields. В идеале я хотел бы создать свой собственный модификатор Textfield, который можно легко применить к представлениям, в которых есть много текстовых полей для редактирования. Я попробовал кучу способов сделать это, но я, должно быть, упустил что -то фундаментальное. Вот один пример. Это
не работает: < /p>
struct ContentView: View {
@State private var searchText = ""
var body: some View {
VStack {
Text("You entered: \(searchText)")
.padding()
TextField("Enter Something", text: $searchText)
.frame(height: 30)
.padding(.leading, 5)
.overlay(
RoundedRectangle(cornerRadius: 6)
.stroke(Color.blue, lineWidth: 1)
)
.padding(.horizontal, 20)
.onChange(of: searchText, perform: { _ in
var subscriptions = Set()
let pub = PassthroughSubject()
pub
.debounce(for: .seconds(1), scheduler: DispatchQueue.main)
.collect()
.sink(receiveValue: { t in
self.searchText = t.first ?? "nothing"
} )
.store(in: &subscriptions)
})
}
}
}
< /code>
Любое руководство будет оценено. XCODE 12.4, iOS 14.4
Подробнее здесь: https://stackoverflow.com/questions/661 ... -textfield
Swiftui Combine Debounce Textfield ⇐ IOS
-
- Похожие темы
- Ответы
- Просмотры
- Последнее сообщение