我一直试图使用Swift为iOS 13开发一个应用程序,但我一直收到一个奇怪的错误:“对成员‘buildBlock()’的模糊引用”。
无论我做什么,错误都不会消失。
我试着一次对代码的各个部分进行注释,看看哪个部分可能导致了问题,但唯一起作用的就是注释掉整个视图。
我已经尝试过清理我的构建文件夹和删除派生数据。我还多次试着重新启动我的电脑和Xcode,没有什么能修复它。
我很确定这只是一个Xcode错误,但肯定有它的存在,如果有人能告诉我这是什么,我会非常感激的。
var body: some View {
GeometryReader { geometry in {
VStack {
Button (action: self.editProfilePicture) {
Image(ImageNames.AccountIconImageName, bundle: Bundle.main)
.resizable()
.frame(width: geometry.size.width / SizeConstants.AccountIconSizeDiviser, height: geometry.size.width / SizeConstants.AccountIconSizeDiviser)
.padding()
.background(ColorConstants.VeryLightGrayColor)
.clipShape(Circle())
}
.accentColor(.white)
.padding(.bottom, LargePadding)
ScrollView (showsVerticalIndicator: false) {
let const: Length? = geometry.size.width - SizeConstants.FullNameTextFieldWidthReduction
TextBox(textBinding: self.$fullName, placeHolder: Text(Strings.FullNameString), editChanged: self.fullNameChanged)/*.padding(.bottom, SmallPadding)*/.frame(width: const)
TextBox(textBinding: self.$username, placeHolder: Text(Strings.UsernameString), editChanged: self.usernameChanged)//.padding(.bottom)
Text(verbatim: Strings.ChooseIdType).font(.footnote).color(.gray)
TextBox(textBinding: self.$phoneNumber, placeHolder: Text(Strings.PhoneNumberString), editChanged: self.phoneNumberChanged)//.padding(.bottom, SmallPadding)
TextBox(textBinding: self.$emailAddress, placeHolder: Text(Strings.EmailAddressString), editChanged: self.emailAddressChanged)//.padding(.bottom)
Spacer(minLength: PaddingConstants.FirstSignupSpacerMinSize)
TextBox(textBinding: self.$password, placeHolder: Text(Strings.PasswordFieldPlaceHolder), editChanged: self.signupPasswordChanged)//.padding(.bottom, SmallPadding)
TextBox(textBinding: self.$confirmPassword, placeHolder: Text(Strings.ConfirmPasswordString), editChanged: self.confirmPasswordChanged)//.padding(.bottom)
Spacer(minLength: PaddingConstants.SecondSignupSpacerMinSize)
Button (action: self.signup) {
Text(Strings.CreateAccountString).color(.white).font(Font.system(size: SizeConstants.LoginButtonFontSize))
}
.padding(EdgeInsets(top: PaddingConstants.CreatAccountButtonVerticalPadding,
leading: PaddingConstants.CreateAccountButtonSidePadding,
bottom: PaddingConstants.CreatAccountButtonVerticalPadding,
trailing: PaddingConstants.CreateAccountButtonSidePadding))
.background(LeznoBlue)
.clipShape(RoundedRectangle(cornerRadius: SmallCornerRadius))
Spacer(minLength: PaddingConstants.ThirdSignupSpacerMinSize)
Text(Strings.AgreementString)
HStack {
Button (action: {}) {
Text(Strings.TermsString)
}
Text(Strings.AndString)
Button (action: {}) {
Text(Strings.PrivacyString)
}
}
}
}
.padding()
}
}编辑:
因此,我忘记了,在视图生成器闭包中,最多只能有10个视图,而且我有更多的视图。只需将它们分组,以减少视图计数,就可以解决错误。
Xcode显示的错误实际上非常具有误导性。
感谢哈米什指出了这一点
发布于 2019-06-19 11:30:28
正如评论中最初提到的@Hamish,ViewBuilders不能超过10个子视图!因此,您应该将项目分组为较小的部分,并尝试逐组添加它们。
因此,而不是这样:(这是一个基于原始代码的工作示例,不完全相同)
struct ContentView : View {
@State var firstName: String = ""
@State var lastName: String = ""
@State var phoneNumber: String = ""
@State var emailAddress: String = ""
@State var password: String = ""
@State var confirmPassword: String = ""
var body: some View {
ScrollView (showsVerticalIndicator: false) {
TextField($firstName, placeholder: Text("First Name"))
TextField($lastName, placeholder: Text("Last Name"))
Spacer()
TextField($phoneNumber, placeholder: Text("Phone Number"))
TextField($emailAddress, placeholder: Text("Email Address"))
Spacer()
TextField($password, placeholder: Text("Password"))
TextField($confirmPassword, placeholder: Text("Confirm Password"))
// ...
}
.padding()
}
}考虑将其分解成有意义的小组,如下所示:
struct NameSectionView : View {
@State var firstName: String
@State var lastName: String
var body: some View {
Group {
TextField($firstName, placeholder: Text("First Name"))
TextField($lastName, placeholder: Text("Last Name"))
}
}
}
struct ContactSectionView : View {
@State var phoneNumber: String
@State var emailAddress: String
var body: some View {
Group {
TextField($phoneNumber, placeholder: Text("Phone Number"))
TextField($emailAddress, placeholder: Text("Email Address"))
}
}
}
struct PasswordSectionView : View {
@State var password: String
@State var confirmPassword: String
var body: some View {
Group {
TextField($password, placeholder: Text("Password"))
TextField($confirmPassword, placeholder: Text("Confirm Password"))
}
}
}像这样使用它们:
struct ContentView : View {
@State var firstName: String = ""
@State var lastName: String = ""
@State var phoneNumber: String = ""
@State var emailAddress: String = ""
@State var password: String = ""
@State var confirmPassword: String = ""
var body: some View {
ScrollView (showsVerticalIndicator: false) {
NameSectionView(firstName: firstName, lastName: lastName)
Spacer()
ContactSectionView(phoneNumber: phoneNumber, emailAddress: emailAddress)
Spacer()
PasswordSectionView(password: password, confirmPassword: confirmPassword)
// ...
}
.padding()
}
}而且,如果您想要在其他地方使用这些功能,这是更可重用的。
https://stackoverflow.com/questions/56655454
复制相似问题