SwiftUI 多个 TextField 导致滞后

dav*_*dev 5 macos swift swiftui

我在我的 SwiftUI Mac OS 应用程序中使用了许多 TextField。我是主窗体,用户在其中添加数据,数据由多个Stacks/组成,views其中包含TextFields/和Text()

我注意到一个奇怪的错误,当我在不同视图中组合使用许多 TextField 时,在选择 TextField 时会出现一些非常严重的滞后。此外,当我跳到下一个时Tab也需要时间。

这真的是很奇怪的行为,我不确定是什么原因造成的。我对很多人TextFields也有不同的看法,一切都在顺利进行。

有时我也不能跳回之前的TextFieldShift+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 上方时,我会立即按下。看到那个滞后..

在此处输入图片说明