我在项目中添加了一个新的nib文件,并尝试加载它。

然而,当我单击工具栏图标(该图标应将我带到我创建的视图)时,我会收到一个NSInternalInconstanceException,消息如下:

由于未捕获异常,正在终止应用“NSInternalInconstanceException”,原因:“-[UIViewController_loadViewFromNibNamed:bundle:]加载了“…”笔尖,但未设置视图出口

所以我打开了我的笔尖文件,看到了没有设置引用出口的视图。然而,我尝试单击并拖动“新引用出口”的圆圈到文件的所有者,但它不允许我……我需要做什么才能显示我的视图?


当前回答

对我来说,这里所说的一切https://stackoverflow.com/a/6395750/939501是真的,但还是抛出了错误,原因是我创建了一个名为ABCView的View类,然后删除了它。后来我添加了一个视图控制器作为ABCViewController,所以它在新的视图控制器中引用了旧的ABCView。我不得不删除ABCViewController并添加一个不同名称的新控件,这解决了我的问题。

谢谢

其他回答

前面的答案几乎为我解决了问题,但最后一步却没有完成。

创建一个同名的xib和swift文件。

将文件所有者设置为UIView子类。

将一个出口从View拖到UIView子类,将其命名为“contentView”

添加此自定义初始值设定项,以便在xib加载时附加contentView

required init?(coder aDecoder: NSCoder) {
        super.init(coder: aDecoder)
        Bundle(for: self.classForCoder).loadNibNamed("SampleView", owner: self, options: nil)
        addSubview(contentView)
        contentView.frame = self.bounds
        contentView.autoresizingMask = [.flexibleHeight, .flexibleWidth]
    }

现在,您添加的任何@IBOutlets都将被附加。

干杯理查德

以下是对我有用的:

打开导致问题的XIB文件单击左栏上的文件所有者图标(顶部的一个,看起来像一个黄色轮廓框)如果您没有看到右侧边栏,请单击工具栏中“视图”上方的第三个图标。这将显示右侧边栏在右侧边栏中,单击第四个选项卡——看起来有点像报纸的选项卡在顶部的“自定义类”下,确保类是与此视图对应的ViewController的名称。如果没有,请输入在右侧边栏中,单击最后一个选项卡,该选项卡看起来像一个带箭头的圆圈你应该看到“outlets”下面有“view”。将旁边的圆圈拖到左栏上的“view”图标上(底部的一个,看起来像一个白色正方形,有一个粗灰色的轮廓保存xib并重新运行

未设置视图标识-类标识。将其设置为适当的类后,问题得到解决。

对我来说,问题是由调用initWithNibName:bundle:引起的。我使用nib文件中的表视图单元格来定义表视图中的条目表单。因为我没有一个观点,所以用一个观点是没有意义的。相反,如果我改为调用initWithStyle:方法,并从那里加载nib文件,那么事情就如预期一样。

如果您使用的是自定义init方法,请检查是否返回了有效的内容。我遇到了一段代码,它在这样的事情上崩溃了:

- (id)init {
   self = [super init];
   if (self) {
      CustomController *controller = [[NSBundle mainBundle] loadNibNamed:NSStringFromClass(className) owner:self options:nil];
   } return self;
}

在另一个类中,控制器是这样创建的:

CustomController *controller = [[CustomController alloc] init];

问题是在init方法中,self没有改变,应该是这样的:

- (id)init {
   self = [super init];
   if (self) {
      CustomController *controller = [[NSBundle mainBundle] loadNibNamed:NSStringFromClass(className) owner:self options:nil];
      [controller viewDidLoad];
      self = controller;
   } return self;
}