[英]Add a prefix to TextField in SwiftUI
我想要一个无法擦除的“+”号文本字段。 用户应该能够在它之后输入值,如果他按下退格键,它应该只擦除他输入的值。 当我写任何其他数字时,它会自动在输入值的开头添加一个“+”。
例如:-我想在文本字段中添加国家/地区代码,因此,一旦用户开始输入国家/地区代码,“+”就会自动添加到字段的开头。
在 SwiftUI 中,您可能希望使用组合框架来执行此操作。 创建一个ObservableObject
来处理值的变化。 示例代码在这里:
import SwiftUI
import Combine
struct ContentView: View {
class ViewModel: ObservableObject {
@Published var text = "" {
didSet {
if text.prefix(1) != "+" {
text = "+" + text
}
}
}
}
@ObservedObject var viewModel = ViewModel()
var body: some View {
TextField("Placeholder", text:$viewModel.text)
}
}
通常你应该在这里发布你的编码尝试,因为这不是一个“我们为你编码”的平台......但是......这是一个阳光明媚的日子,所以这里是代码;)
override func viewDidLoad() {
super.viewDidLoad()
// Do any additional setup after loading the view.
let textField = UITextField(frame: CGRect(x: 100, y: 100, width: 200, height: 20))
view.addSubview(textField)
textField.addTarget(self, action: #selector(textFieldDidChange(_:)), for: UIControl.Event.editingChanged)
textField.layer.borderColor = UIColor.red.cgColor
textField.layer.borderWidth = 2
}
@objc func textFieldDidChange(_ textField: UITextField) {
if textField.text?.prefix(1) != "+" {
textField.text = "+" + textField.text!
}
}
import SwiftUI
struct ContentView: View {
@State var userName : String = ""
var body: some View {
VStack {
HStack{
Image(systemName: "plus")
TextField("placeholder",text:$userName)
}
.padding(5)
.foregroundColor(.white)
.background(Capsule().fill(Color.gray))
Spacer()
}.padding(5)
}
}
struct ContentView_Previews: PreviewProvider {
static var previews: some View {
ContentView()
}
}
我会说这是添加“+”号的更好方法,这样您在访问userName时就不会收到+号
我需要在我的应用程序中使用相同的功能(用户需要输入国家/地区代码以便我可以验证号码),并且我使用自定义绑定实现了与您想要的类似的功能:
struct PrefixedTextField: View {
@State private var countryCode = "+"
var body: some View {
let countryCodeCustomBinding =
Binding(
get: { self.countryCode },
set: {
self.countryCode = $0
if self.countryCode.isEmpty { self.countryCode = "+" }
})
return TextField("+91", text: countryCodeCustomBinding).keyboardType(.numberPad)
}
}
尝试用我的“kg”替换“+”
func textField(_ textField: UITextField, shouldChangeCharactersIn range: NSRange, replacementString string: String) -> Bool {
var amountTypedString = myTF.text
if string.count > 0 {
if amountTypedString?.count ?? 0 > 2 {
amountTypedString = String((amountTypedString?.dropLast(2))!)
}
amountTypedString! += string
let newString = amountTypedString! + "kg"
myTF.text = newString
} else {
amountTypedString = String((amountTypedString?.dropLast(3))!)
if (amountTypedString?.count)! > 0 {
let newString = amountTypedString! + "kg"
myTF.text = newString
} else {
myTF.text = ""
}
}
return false
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.