保持iOS SwiftUI TextField的键盘在屏幕上,直到用户输入正确的内容。
创始人
2024-11-21 18:00:44
0

要实现在用户输入正确内容之前保持键盘在屏幕上,可以结合使用TextFieldObservableObjectonReceive修饰符。以下是一个示例代码:

首先,创建一个名为InputValidatorObservableObject类,用于验证用户输入是否正确并保持键盘在屏幕上:

import SwiftUI
import Combine

class InputValidator: ObservableObject {
    @Published var input: String = ""
    @Published var isInputValid: Bool = false
    
    private var cancellables = Set()
    
    init() {
        $input
            .map { input in
                // 在这里根据需要执行输入验证逻辑
                return input.count >= 6  // 假设验证逻辑为输入长度至少为6
            }
            .assign(to: \.isInputValid, on: self)
            .store(in: &cancellables)
    }
}

接下来,在您的视图中使用TextFieldonReceive修饰符来保持键盘在屏幕上,直到用户输入正确的内容:

import SwiftUI

struct ContentView: View {
    @ObservedObject var inputValidator = InputValidator()

    var body: some View {
        VStack {
            TextField("请输入内容", text: $inputValidator.input)
                .textFieldStyle(RoundedBorderTextFieldStyle())
                .padding()
                .onReceive(inputValidator.$isInputValid) { isInputValid in
                    if isInputValid {
                        // 输入正确,关闭键盘
                        UIApplication.shared.sendAction(#selector(UIResponder.resignFirstResponder), to: nil, from: nil, for: nil)
                    } else {
                        // 输入错误,弹出键盘
                        UIApplication.shared.sendAction(#selector(UIResponder.becomeFirstResponder), to: nil, from: nil, for: nil)
                    }
                }
            
            Button(action: {
                // 处理提交逻辑
            }) {
                Text("提交")
                    .font(.headline)
                    .foregroundColor(.white)
                    .padding()
                    .background(Color.blue)
                    .cornerRadius(10)
            }
            .disabled(!inputValidator.isInputValid)
        }
    }
}

在上述示例中,InputValidator类用于验证输入,并将结果通过isInputValid属性发布给视图。然后,使用onReceive修饰符在输入有效性更改时执行相应的操作。如果输入有效,将关闭键盘;如果输入无效,将弹出键盘。

请注意,为了使键盘在屏幕上保持,我们使用UIApplication.shared.sendAction发送了resignFirstResponderbecomeFirstResponder动作。这些动作会模拟用户手动关闭和弹出键盘。

相关内容

热门资讯

一分钟了解!樱花之盛辅助软件下... 一分钟了解!樱花之盛辅助软件下载!竟然真的有辅助app(有挂工具)-哔哩哔哩樱花之盛辅助软件下载破解...
6分钟了解!福建兄弟13水修改... 6分钟了解!福建兄弟13水修改器!一直是有辅助软件(有挂技术)-哔哩哔哩1)福建兄弟13水修改器免费...
第9分钟了解!顺欣茶坊智能辅助... 第9分钟了解!顺欣茶坊智能辅助器使用说明书!一贯一直总是有辅助软件(有挂解惑)-哔哩哔哩1、打开软件...
6分钟了解!四川游戏家园辅助软... 6分钟了解!四川游戏家园辅助软件!都是真的有辅助教程(有挂辅助)-哔哩哔哩;1、金币登录送、破产送、...
5分钟了解!约局吧脚本有用码!... 5分钟了解!约局吧脚本有用码!一直真的有辅助app(有挂方法)-哔哩哔哩运约局吧脚本有用码辅助工具,...
六分钟了解!八仙竞技馆辅助!一... 六分钟了解!八仙竞技馆辅助!一直一直总是有辅助技巧(有挂技术)-哔哩哔哩八仙竞技馆辅助辅助器是一种具...
第三分钟了解!途游四川辅助器小... 第三分钟了解!途游四川辅助器小程序!切实有辅助app(确实有挂)-哔哩哔哩该软件可以轻松地帮助玩家将...
2分钟了解!贰柒拾智能辅助柒!... 2分钟了解!贰柒拾智能辅助柒!切实真的是有辅助神器(有挂工具)-哔哩哔哩1、操作简单,无需贰柒拾智能...
第7分钟了解!乐酷副厅房间科技... 第7分钟了解!乐酷副厅房间科技!果然有辅助app(有挂规律)-哔哩哔哩1、操作简单,无需乐酷副厅房间...
七分钟了解!多乐跑得快私人房间... 七分钟了解!多乐跑得快私人房间作必弊视频!其实是真的有辅助教程(真的有挂)-哔哩哔哩1、不需要AI权...