多行文本输入目前在 SwiftUI 中不受本机支持(希望很快添加此功能!)所以我一直在尝试使用组合框架从 UIKit 实现支持多行输入的 UITextView,但是我的结果喜忧参半.
这是我创建的用于制作文本视图的代码:
struct MultilineTextView: UIViewRepresentable {
@Binding var text: String
func makeUIView(context: Context) -> UITextView {
let view = UITextView()
view.isScrollEnabled = true
view.isEditable = true
view.isUserInteractionEnabled = true
view.backgroundColor = UIColor.white
view.textColor = UIColor.black
view.font = UIFont.systemFont(ofSize: 17)
view.delegate = context.coordinator
return view
}
func updateUIView(_ uiView: UITextView, context: Context) {
uiView.text = text
}
func frame(numLines: CGFloat) -> some View {
let height = UIFont.systemFont(ofSize: 17).lineHeight * numLines
return self.frame(height: height)
}
func makeCoordinator() -> MultilineTextView.Coordinator {
Coordinator(self)
}
class Coordinator: NSObject, UITextViewDelegate {
var parent: MultilineTextView
init(_ parent: MultilineTextView) {
self.parent = parent
}
func textViewDidChange(_ textView: UITextView) {
parent.text = textView.text
}
}
}
Run Code Online (Sandbox Code Playgroud)
然后我在 swiftUI 视图中实现了它,例如:
MultilineTextView(text: title ? $currentItem.titleEnglish : $currentItem.pairArray[currentPair].english)//.frame(numLines: 4)
Run Code Online (Sandbox Code Playgroud)
并将其绑定到状态变量:
@State var currentItem:Item
Run Code Online (Sandbox Code Playgroud)
它有点工作。但是,状态 var currentItem:Item 包含一个字符串数组,然后我将使用按钮循环遍历这些字符串,这些按钮根据输入到 MultilineTextView 中的内容更新字符串数组。这是我遇到的问题,其中 MultilineTextView 似乎只绑定到数组中的第一个字符串项,然后它不会改变。当我使用 swiftUI 的原生 TextField 视图时,此功能工作正常,我可以循环遍历字符串数组并通过将文本输入到 TextField 来更新它。
我想我一定在 MultilineTextView 结构中遗漏了一些东西来允许这个功能。任何指点都非常感谢。
更新:添加模型结构
struct Item: Identifiable, Codable {
let id = UUID()
var completed = false
var pairArray:[TextPair]
}
struct TextPair: Identifiable, Codable {
let id = UUID()
var textOne:String
var textTwo:String
}
Run Code Online (Sandbox Code Playgroud)
编辑: 所以我做了更多的挖掘,我发现了我认为的问题。当 UITextView 的 textViewDidChange 被触发时,它会发送我可以在控制台中看到的更新文本。奇怪的是,随后 updateUIView 函数也被触发,并在通过 textViewDidChange 发送更新之前使用绑定变量中的内容更新 UITextView 的文本。结果是 UITextview 在您输入时拒绝更改。奇怪的是,它适用于数组中的第一个 String,但是当该项目被更改时,它将不再起作用。
看来 SwiftUIUIViewRepresentable为每个绑定创建了 , 的两个变体,但在状态(即切换)时不会切换它们title......可能是由于缺陷,值得提交给 Apple。
我找到了可行的解决方法(使用 Xcode 11.2 / iOS 13.2 进行测试),而是使用明确不同的视图,如下所示
if title {
MultilineTextView(text: $currentItem.titleEnglish)
} else {
MultilineTextView(text: $currentItem.pairArray[currentPair].textOne)
}
Run Code Online (Sandbox Code Playgroud)
| 归档时间: |
|
| 查看次数: |
3490 次 |
| 最近记录: |