dav*_*dev 5 macos swift swiftui
我在我的 SwiftUI Mac OS 应用程序中使用了许多 TextField。我是主窗体,用户在其中添加数据,数据由多个Stacks/组成,views其中包含TextFields/和Text()
我注意到一个奇怪的错误,当我在不同视图中组合使用许多 TextField 时,在选择 TextField 时会出现一些非常严重的滞后。此外,当我跳到下一个时Tab也需要时间。
这真的是很奇怪的行为,我不确定是什么原因造成的。我对很多人TextFields也有不同的看法,一切都在顺利进行。
有时我也不能跳回之前的TextField用Shift+Tab。
编辑:我可以弄清楚如何摆脱它。但是,仅当我删除一个视图时。我不想。
我的主容器看起来像这样:
HStack
{
//Left Side
VStack{
Text("Here is the next #1")
}
VStack
{
//The View posted below
ViewBelow()
}
}
Run Code Online (Sandbox Code Playgroud)
如果我删除第一个 VStack,问题就解决了。没有什么滞后。如果我添加它,它会再次出现。
只是为了给你一个我的代码的领口(许多带有 TextFields 的堆栈)
ZStack
{
VStack
{
HStack
{
Text("Personal Data")
.font(.title)
.fontWeight(.bold)
.padding(.horizontal, 0)
.padding(.vertical, 5)
Spacer()
}
Divider()
.padding(.bottom, 5)
//Personal Data Types
HStack(spacing: 0)
{
//Left Element
VStack(alignment: .center)
{
Text("Vorname")
.foregroundColor(Color.gray)
} .frame(minWidth: 0, maxWidth: .infinity, alignment: .leading)
//Right Elemenet
VStack()
{
Text("Nachname")
.foregroundColor(Color.gray)
}
.frame(minWidth: 0, maxWidth: .infinity, alignment: .leading)
}.frame(minWidth: 0, maxWidth: .infinity)
HStack(spacing: 0)
{
VStack(alignment: .center)
{
//Left Element
if (self.editMode)
{
TextField("Enter some text", text: $s_test)
.frame(maxWidth:250)
}
else
{
Text(self.person.firstName)
.font(.body)
}
} .frame(minWidth: 0, maxWidth: .infinity, alignment: .leading)
VStack()
{
//Left Element
if (self.editMode)
{
TextField("Enter some text", text: self.$s_test)
.frame(maxWidth:250)
}
else
{
Text(self.person.lastName)
.font(.body)
}
}
.frame(minWidth: 0, maxWidth: .infinity, alignment: .leading)
}.frame(minWidth: 0, maxWidth: .infinity)
.padding(.top, 0)
//Personal Data Types
HStack(spacing: 0)
{
//Left Element
VStack(alignment: .center)
{
Text("Nickname")
.foregroundColor(Color.gray)
} .frame(minWidth: 0, maxWidth: .infinity, alignment: .leading)
//Right Elemenet
VStack()
{
Text("Birthday")
.foregroundColor(Color.gray)
}
.frame(minWidth: 0, maxWidth: .infinity, alignment: .leading)
}.frame(minWidth: 0, maxWidth: .infinity)
.padding(.top, 10)
HStack(spacing: 0)
{
VStack(alignment: .center)
{
//Left Element
if (self.editMode)
{
TextField("Enter some text", text: self.$s_test)
.frame(maxWidth:250)
}
else
{
Text(self.person.nickname)
.font(.body)
}
} .frame(minWidth: 0, maxWidth: .infinity, alignment: .leading)
VStack()
{
//Right Element
if (self.editMode)
{
TextField("Enter some text", text: self.$s_test)
.frame(maxWidth:250)
}
else
{
Text(self.person.birthdate)
.font(.body)
}
}
.frame(minWidth: 0, maxWidth: .infinity, alignment: .leading)
}.frame(minWidth: 0, maxWidth: .infinity)
.padding(.top, 0)
}
Run Code Online (Sandbox Code Playgroud)
也许有人已经经历过同样的事情..我不确定如何解决它。我删除了许多视图,然后它工作得更好。但是我不确定它是否只是 TextFields 的数量或其他视图中的一些错误。
我演示了 Gif 中的滞后。当我将鼠标悬停在 TextField 上方时,我会立即按下。看到那个滞后..
| 归档时间: |
|
| 查看次数: |
736 次 |
| 最近记录: |