尝试通过连接绑定(bind)到属性 (optionSegment) 来设置 NSToolbarItem 的选定段,这是一个 NSSegmentedControl。子类化窗口 Controller
class MyWindow: NSWindowController {
dynamic var optionSegment: Int = 0
override func windowDidLoad() {
super.windowDidLoad()
}
}
或者,将 optionSegment 属性放在 NSDocument 子类中并绑定(bind)到它。每项工作。问题是,使用此绑定(bind),或看似与 NSToolbarItem 的任何绑定(bind),我的所有对象( View 、 View Controller 、文档等)都不会取消初始化。有了绑定(bind),他们就不会。删除绑定(bind),他们就会这样做。
知道为什么会这样吗?建议?非常难过。
谢谢!
最佳答案
正如 Willeke 所建议的,toolbarItem.view 是通往成功的道路。不得不说对象的层次结构对我来说并不总是很清楚,但是 .view 似乎是唯一的可能性,因为我一夜之间查看了 toolbarItem Hook ,Willeke 的建议证实了这一点。有关绑定(bind)的 Apple 文档确实提到我们有责任解除某些对象的绑定(bind),同时解除其他对象的绑定(bind)。这是我放入 NSDocument 子类中的代码,用于取消绑定(bind)所有内容, View Controller 现在正在取消初始化。
func windowWillClose(notification: NSNotification) {
let wcs = self.windowControllers
if wcs.count == 0 { return }
let wc = wcs[0]
let toolbar = wc.window?.toolbar
if toolbar != nil {
let items = toolbar!.items
for item in items {
let v = item.view
if v != nil {
// print(v?.className)
let objects = v!.exposedBindings
for object in objects {
// print(object + " " + item.label + " " + v!.className)
v!.unbind(object)
}
}
}
}
}
这是我遇到过的最令人困惑的概念之一——太多的事件部分——感谢 Willeke 和 stevesliva 的对话,最终找到了解决方案。
来自 NSObject(NSKeyValueBindingCreation):
All standard bindings on AppKit objects (views, cells, table columns, controllers) unbind their bindings automatically when they are deallocated, but if you create key-value bindings for other kind of objects, you need to make sure that you remove those bindings before deallocation (observed objects have weak references to their observers, so controllers/model objects might continue referencing and messaging the objects that were bound to them).
关于swift - 绑定(bind)到 NSToolbarItem 的 Cocoa 连接是否会阻止取消初始化?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/36752294/
给定这段代码defcreate@upgrades=User.update_all(["role=?","upgraded"],:id=>params[:upgrade])redirect_toadmin_upgrades_path,:notice=>"Successfullyupgradeduser."end我如何在该操作中实际验证它们是否已保存或未重定向到适当的页面和消息? 最佳答案 在Rails3中,update_all不返回任何有意义的信息,除了已更新的记录数(这可能取决于您的DBMS是否返回该信息)。http://ar.ru
在我的gem中,我需要yaml并且在我的本地计算机上运行良好。但是在将我的gem推送到rubygems.org之后,当我尝试使用我的gem时,我收到一条错误消息=>"uninitializedconstantPsych::Syck(NameError)"谁能帮我解决这个问题?附言RubyVersion=>ruby1.9.2,GemVersion=>1.6.2,Bundlerversion=>1.0.15 最佳答案 经过几个小时的研究,我发现=>“YAML使用未维护的Syck库,而Psych使用现代的LibYAML”因此,为了解决
这个问题在这里已经有了答案:Checktoseeifanarrayisalreadysorted?(8个答案)关闭9年前。我只是想知道是否有办法检查数组是否在增加?这是我的解决方案,但我正在寻找更漂亮的方法:n=-1@arr.flatten.each{|e|returnfalseife
它不等于主线程的binding,这个toplevel作用域是什么?此作用域与主线程中的binding有何不同?>ruby-e'putsTOPLEVEL_BINDING===binding'false 最佳答案 事实是,TOPLEVEL_BINDING始终引用Binding的预定义全局实例,而Kernel#binding创建的新实例>Binding每次封装当前执行上下文。在顶层,它们都包含相同的绑定(bind),但它们不是同一个对象,您无法使用==或===测试它们的绑定(bind)相等性。putsTOPLEVEL_BINDINGput
我在Rails工作并有以下类(class):classPlayer当我运行时bundleexecrailsconsole然后尝试:a=Player.new("me",5.0,"UCLA")我回来了:=>#我不知道为什么Player对象不会在这里初始化。关于可能导致此问题的操作/解释的任何建议?谢谢,马里奥格 最佳答案 havenoideawhythePlayerobjectwouldn'tbeinitializedhere它没有初始化很简单,因为你还没有初始化它!您已经覆盖了ActiveRecord::Base初始化方法,但您没有调
我有一个包含多个键的散列和一个字符串,该字符串不包含散列中的任何键或包含一个键。h={"k1"=>"v1","k2"=>"v2","k3"=>"v3"}s="thisisanexamplestringthatmightoccurwithakeysomewhereinthestringk1(withspecialcharacterslike(^&*$#@!^&&*))"检查s是否包含h中的任何键的最佳方法是什么,如果包含,则返回它包含的键的值?例如,对于上面的h和s的例子,输出应该是v1。编辑:只有字符串是用户定义的。哈希将始终相同。 最佳答案
我需要检查DateTime是否采用有效的ISO8601格式。喜欢:#iso8601?我检查了ruby是否有特定方法,但没有找到。目前我正在使用date.iso8601==date来检查这个。有什么好的方法吗?编辑解释我的环境,并改变问题的范围。因此,我的项目将使用jsapiFullCalendar,这就是我需要iso8601字符串格式的原因。我想知道更好或正确的方法是什么,以正确的格式将日期保存在数据库中,或者让ActiveRecord完成它们的工作并在我需要时间信息时对其进行操作。 最佳答案 我不太明白你的问题。我假设您想检查
我的日期格式如下:"%d-%m-%Y"(例如,今天的日期为07-09-2015),我想看看是不是在过去的七天内。谁能推荐一种方法? 最佳答案 你可以这样做:require"date"Date.today-7 关于ruby-检查日期是否在过去7天内,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/32438063/
这里有一个很好的答案解释了如何在Ruby中下载文件而不将其加载到内存中:https://stackoverflow.com/a/29743394/4852737require'open-uri'download=open('http://example.com/image.png')IO.copy_stream(download,'~/image.png')我如何验证下载文件的IO.copy_stream调用是否真的成功——这意味着下载的文件与我打算下载的文件完全相同,而不是下载一半的损坏文件?documentation说IO.copy_stream返回它复制的字节数,但是当我还没有下
我有用于控制用户任务的Rails5API项目,我有以下错误,但并非总是针对相同的Controller和路由。ActionController::RoutingError:uninitializedconstantApi::V1::ApiController我向您描述了一些我的项目,以更详细地解释错误。应用结构路线scopemodule:'api'donamespace:v1do#=>Loginroutesscopemodule:'login'domatch'login',to:'sessions#login',as:'login',via::postend#=>Teamroutessc