gpt4 book ai didi

ios - SwiftUI 在一种情况下查看层次结构警告,而不是另一种情况

转载 作者:行者123 更新时间:2023-11-29 05:25:06 25 4
gpt4 key购买 nike

我最初制作了一个 SwiftUI 列表/详细信息应用程序,其中包含一个 TabView,其中一个选项卡作为添加新记录的 View 。这几乎符合预期。我想更改从选项卡添加功能以从导航栏按钮调用。我在这两种情况下使用完全相同的 View 。当从导航栏按钮调用 View 时,我收到 tableView 层次结构错误:

[TableView] 仅警告一次:UITableView 被告知布局其可见单元格并不在 View 层次结构中的其他内容( TableView 或其之一) super View 尚未添加到窗口中)...+更多的闲聊

TabView 调用:

AddNewPatient().tabItem ({
Image(systemName: "plus.circle")
Text("Add")
})
.tag(2)

导航按钮调用:

.navigationBarItems(trailing: NavigationLink(destination: AddNewPatient()) {
Text("Add Patient")
})

我很困惑为什么从导航栏按钮调用时 View 超出层次结构。到目前为止,我还没有遇到应用程序崩溃的情况,但显然该应用程序不满意。数据确实已保存并显示在列表中。 (核心数据存储)

我在 UITableViewAlertForLayoutOutsideViewHierarchy 设置了一个符号断点,但我所有可以收集到相同的数据 - 在 View 层次结构之外。

Xcode 11.1 (11A1027) iOS 13.1.2

如有任何指导,我们将不胜感激。

AddNewPatient View :

import SwiftUI
import CoreData

struct AddNewPatient: View {

@Environment(\.managedObjectContext) var managedObjectContext
@Environment(\.presentationMode) var presentationMode

@State private var updatedTitle: String = "No Title"
@State private var updatedFirstName: String = "No First Name"
//more properties

@State var photos: [UIImage] = [UIImage]()
@State private var showImagePicker: Bool = false

var bImage: Image = Image("InventoryThinBlueWithCamera")

var body: some View {
NavigationView {
ScrollView {
VStack {
if photos.count > 0 {
Image(uiImage: photos[photos.count - 1])
.resizable()
.frame(width: 320, height: 320)
.aspectRatio(contentMode: .fit)
.cornerRadius(12)
} else {
bImage
}

VStack {
Button("Take Photo") {
self.showImagePicker = true
}
.padding()
.background(Color.green)
.foregroundColor(.white)
.cornerRadius(12)
//.disabled(!showAlert)
}
.sheet(isPresented: self.$showImagePicker) {
PhotoCaptureView(photos: self.$photos)
}

VStack(alignment: .leading) {
Text("Patient Title:")
.padding(.leading, 5)
.font(.headline)
TextField("Enter a Title", text: $updatedTitle)
.onAppear {
self.updatedTitle = ""
}
.textFieldStyle(RoundedBorderTextFieldStyle())
}
.padding(10)


VStack(alignment: .leading) {
Text("First Name:")
.padding(.leading, 5)
.font(.headline)
TextField("Enter First Name", text: $updatedFirstName)
.onAppear {
self.updatedFirstName = ""
}
.textFieldStyle(RoundedBorderTextFieldStyle())
}
.padding(10)

//bunch more fields



Spacer()
}
}//ScrollView
.navigationBarTitle("Add New Patient", displayMode: .inline)
.padding(.top, 50)
.navigationBarItems(trailing: Button(action: ({

let nmo = Patient(context: self.managedObjectContext)
var chosenImageData : Data?

if self.photos.count > 0 {
let theImage = self.photos[self.photos.count - 1]

let rir = CRSReduceImageResolution()
let temp = rir.resizeMyImageData(theImage, startSize: CGSize.zero, endSize: CGSize(width: 320, height: 240))
chosenImageData = temp
//chosenImageData = myImageData
nmo.image = chosenImageData
}

nmo.myID = UUID()
nmo.title = self.updatedTitle
nmo.firstName = self.updatedFirstName
nmo.lastName = self.updatedLastName
nmo.createdAt = Date()

do {
try self.managedObjectContext.save()
} catch {
print(error)
}

self.photos = []
self.updatedTitle = ""
self.updatedFirstName = ""
//bunch more fields
})) {
Text("Save")
})
}//nav
}
}

最佳答案

我更改了尾随按钮调用以切换属性以显示添加患者表,然后调用函数来添加患者。这非常有效。

 .navigationBarTitle("Person")
.sheet(isPresented: $showAddPatient) {
AddNewPatient(photoStore: self.photoStore)
}

.navigationBarItems(
leading: EditButton(),
trailing: Button(
action: {
withAnimation { self.showAddPatient.toggle() }
}
) {
Image(systemName: "plus")
}

关于ios - SwiftUI 在一种情况下查看层次结构警告,而不是另一种情况,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/58244803/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com