jqmodal и nyromodal не будут работать с Jquery 1.3.2 и расширением панели инструментов Firefox.
Вопрос
Я пытался создать свою собственную панель инструментов Firefox с командами, которые будут открывать и закрывать модальное диалоговое окно, используя jqModal или nyroModal.В обоих случаях открытие диалогового окна вызывает ошибки, и я не могу найти ничего о том, почему модальные окна могут сломаться.
Браузер:Firefox 3.0.11 jQuery:v1.3.2 jqmodal:R14 Nyromodal:1.5.0
Пример XUL:`
<!-- required JQuery dependency -->
<!--script src="chrome://jqmtoolbar/content/jquery.js" /-->
`<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.3.2/jquery.min.js" />
<!-- load main library -->
<script src="chrome://jqmtoolbar/content/jquery.nyroModal-1.5.0.pack.js" type="application/x-javascript" />
<script src="http://www.nopuck4you.com/gooble/jqModal-dev.js" type="application/x-javascript" />
<script src="chrome://jqmtoolbar/content/jqm.js" type="application/x-javascript" />
<toolbox id="navigator-toolbox">
<toolbar id="modal-toolbar" toolbarname="modal test toolbarx" accesskey="G"
class="chromeclass-toolbar" context="toolbar-context-menu"
hidden="false" persist="hidden">
<toolbarbutton id="gb-debug-jqmShow" tooltiptext="Show Modal"
label="Show Modal" oncommand="jqmShowModal(event)" />
<toolbarbutton id="gb-debug-jqmHide" tooltiptext="Hide Modal"
label="Hide Modal" oncommand="jqmHideModal(event)" />
<toolbarspring/>
<toolbarseparator/>
<toolbarbutton id="gb-debug-nyroShow" tooltiptext="Show Modal"
label="Show Modal" oncommand="nyroShowModal(event)" />
<toolbarbutton id="gb-debug-nyroHide" tooltiptext="Hide Modal"
label="Hide Modal" oncommand="nyroHideModal(event)" />
<toolbarspring/>
</toolbar>
</toolbox>
`
Пример файла jqm.js:`function jqmshowmodal (e) {// LoadPageHeadElements ();var body = $(content.document).find("ТЕЛО");if(body.find("#jqmModal").length == 0) body.prepend("Привет, jqModal!");var jq = $("#jqmModal", content.document);
jq.jqm({
//set JQ modal parameters
ajax: "http://www.google.com",
modal: true,
onLoad: choke
});
$("#jqmModal").jqmShow();
//$("#goobModal", content.document).jqmShow();
}
функция nyroshowmodal (e) {
//loadPageHeadElements();
var body = $(content.document).find("BODY");
if(body.find("#nyroModal").length == 0) body.prepend("<div id=\"nyroModal\">Hello Nyro Modal!</div>");
var nym = $("#nyroModal", content.document);
nym.nyroModalManual({url: 'http://www.google.com'});
//nym.nyroModalManual({content: '<div>Hello from the test toolbar!</div>'});
}
Функция удушья (e) {alert ('choke!');} `
Решение
Похоже, единственный способ справиться с этим — использовать объект панели инструментов вместо модальных окон.