很多时候,我有一个问题,并发布了帮助,那么多次,QueryInterface是解决方案。我已经做了很长一段时间的插件编程了,但是我从来没有理解过QueryInterface。它看起来像魔法,好像它能解决所有的问题。
像这样:
window.QueryInterface(Ci.nsIInterfaceRequestor)
.getInterface(Ci.nsIWebNavigation)
.QueryInterface(Ci.nsIDocShellTreeItem)
.rootTreeItem
.QueryInterface(Ci.nsIInterfaceRequestor)
.getInterface(Ci.nsIDOMWindow);所以我的问题是,我看到了一个QueryInterface链,我不明白为什么是这个链,我肯定也不知道如何创建我自己的链。我不明白你怎么知道从nsiInterfaceRequester到nsiWebNavigation而不是从nsiInterfaceRequester直接到nsiDOMWindow
发布于 2014-03-01 23:33:25
这里真的没有什么特别的地方。DOM实现了允许获取相关对象的nsIInterfaceRequestor接口。其中一个对象是与窗口相关联的docshell --您可以通过请求nsIWebNavigation接口来获得它,但它也实现了nsIDocShell和nsIDocShellTreeItem接口以及nsIInterfaceRequestor。尽管chrome和content之间存在安全边界,但当前窗口的docshell允许您访问顶部窗口的docshell。在这里,您可以再次使用nsIInterfaceRequestor接口向docshell请求与其关联的窗口。
您只需在XPCOM组件中实现nsIInterfaceRequestor接口,就像任何其他接口一样。我不认为有任何理由这样做,然而,隐藏与窗口相关的内部接口对DOM是一个丑陋的黑客。
https://stackoverflow.com/questions/21629192
复制相似问题