0
我已经使用此代码来配置窗口。它已经工作过。为什么我每次访问`self.window`时都加载了我的窗口
- (void)awakeFromNib
{
NSLog(@"self = %p", self);
[(NSPanel *)self.window setWorksWhenModal: NO];
}
无论如何,每次我访问self.window
窗口是从笔尖加载。这是一个问题,因为它使这个递归。但它在其他地方也是一个问题,因为我每次都会得到不同的窗口!
从 “NSWindowController”:
/* The window getter will load the nib file (if there is one and it has not yet been loaded) and then return the window.
If it has to load the window, it will first call -windowWillLoad, then -loadWindow, then -windowDidLoad.
To affect nib loading or do something before or after it happens, you should always override those other methods.
The window setter is used internally from -initWithWindow: or when a controller's nib file is loaded (as the "window" outlet gets connected).
You can also call it yourself if you want to create the window for a window controller lazily, but you aren't loading it from a nib.
This can also be used to set the window to nil for cases where your subclass might not want to keep the window it loaded from a nib, but rather only wants the contents of the window.
Setting the window to nil, after the nib has been loaded, does not reset the -isWindowLoaded state.
A window controller will only load its nib file once. This method makes sure the window does not release when closed, and it sets the controller's -windowFrameAutosaveName onto the window and updates the window's dirty state to match the controller's document (if any).
It also calls -setWindowController: on the window. You can override this if you need to know when the window gets set, but call super.
*/
@property (nullable, strong) NSWindow *window;
哦,就是这样。我在窗口NIB中有控制器对象!谢谢! – netigger
或等待,让我再次验证这个..刚刚重新创建它,现在在NIB没有任何对象,但仍然得到它,生病回来。 – netigger
我其实还是有问题的。但是我仍然在从awakeFromNib访问'self.window',但是现在看起来效果很好,现在我也删除了它 – netigger