我试图通过javascript访问XUL Panel Element来动态打开和关闭它。
<?xml version="1.0"?>
<?xml-stylesheet type="text/css" href="chrome://global/skin/" ?>
<?xml-stylesheet type="text/css"
href="chrome://textareaautocomplete/skin/browserOverlay.css" ?>
<!DOCTYPE overlay SYSTEM
"chrome://textareaautocomplete/locale/browserOverlay.dtd">
<overlay id="textareaautocomplete-browser-overlay"
xmlns="http://www.mozilla.org/keymaster/gatekeeper/there.is.only.xul">
<script type="application/x-javascript"
src="chrome://textareaautocomplete/content/browserOverlay.js" />
<stringbundleset id="stringbundleset">
<stringbundle id="textareaautocomplete-string-bundle"
src="chrome://textareaautocomplete/locale/browserOverlay.properties" />
</stringbundleset>
<menupopup id="menu_ToolsPopup">
<menu id="xs-textareaautocomplete-menu" label="&textareaautocomplete.menu.label;"
accesskey="&textareaautocomplete.menu.accesskey;"
insertafter="javascriptConsole,devToolsSeparator">
<menupopup>
<menuitem id="textareaautocomplete-ta-menu-item"
label="&textareaautocomplete.cache.start.label;"
accesskey="&textareaautocomplete.cache.accesskey;"
oncommand="TextareaAutocomplete.BrowserOverlay.main();" />
</menupopup>
</menu>
</menupopup>
<panel id="textareaautocomplete-ta-dropdown-panel">
<textbox id="search"/>
</panel>
</overlay>
try {
let panel = document.getElementById("textareaautocomplete-ta-dropdown-panel");
panel.openPopup(node, "after_start", 0, 0, false, false);
}
catch(e) {
window.alert("Failed to set drop down: " + e.name + ": " + e.message);
}
这在异常中给出了以下错误消息:
panel is null
如果遗漏或不对,请告诉我!还有一点是我可以通过更改相同javascript代码中的id来访问stringbundleset,menupopup等其他元素。
答案 0 :(得分:1)
将您的面板包裹在vbox或hbox中 例如:在你的情况下
<hbox>
<panel id="textareaautocomplete-ta-dropdown-panel">
<textbox id="search"/>
</panel>
<hbox>