Я создаю сценарий Greasemonkey, чтобы автоматизировать настройку некоторых параметров в нашей системе онлайн-продажи билетов, чтобы сделать регистрацию вызовов немного более эффективной.
В любом случае, экран для регистрации звонков состоит из нескольких кадров, только один из них представляет интерес для меня с точки зрения автоматизации. Выделенный HTML-код для страницы и фрейма (включая элемент, который я пытаюсь редактировать) выглядят следующим образом:
<html>
<head>
</head>
<frameset framespacing="0" border="0" bordercolor="#ffffff" rows="130,*,22,0">
<frame scrolling="no" marginwidth="0" marginheight="0" leftmargin="0" topmargin="0" noresize="" src="top.asp?menu=&page=" name="menu">
</frame>
<frameset id="contentCols" framespacing="8" border="8" cols="250, *" bordercolor="#ffffff">
<frame marginwidth="0" marginheight="0" leftmargin="0" topmargin="0" border="0" src="../service/loading.html" name="content" frameborder="0" style="padding-right: 10px;">
<html>
<head>
</head>
<body class="winBack" style="background-color: rgb(255, 255, 255);">
<div id="scrollableContainer" class="lockedTableContainer scrollableContainerHeight" style="position: relative; height: 0px;">
<table cellspacing="1" cellpadding="3" border="0">
<form id="configFields" name="configFields" method="post" action="/ics/tt/ticketNew.asp"></form>
<input type="hidden" value="" name="task">
<input type="hidden" value="account" name="source">
<tbody>
<tr id="ROW_109094">
<td class="webCaption" style="width: 160px;">
</td>
<td class="formText">
<select id="FIELD_109094_DROPDOWN_null" class="formText" style="width: 200px;" title="Establishment Type" name="FIELD_109094_DROPDOWN_null" onchange="updateDep(109094, this.options[this.selectedIndex].value);">
</select>
</td>
</tr>
</tbody>
<table>
</div>
</frame>
</frameset>
</frameset>
</html>
Я пытаюсь установить selectedIndex
элемента FIELD_109094_DROPDOWN_null
select.
Затем я пытаюсь запустить функцию updateDep
(которая содержится в скрипте, прикрепленном к фрейму), который присоединен к событию изменения элемента; эта функция показывает некоторые другие поля в зависимости от значения, установленного в данный момент в элементе select.
Используя консоль Firebug, я могу добиться этого, используя следующие две строки:
frames["content"].document.getElementById("FIELD_109094_DROPDOWN_null").selectedIndex = 2;
frames["content"].updateDep(109094, frames["content"].document.getElementById("FIELD_109094_DROPDOWN_null").options[2].value);
Однако, когда я помещаю это в скрипт Greasemonkey и присоединяю его либо к загрузке основного окна, либо к загрузке фрейма; Я получаю эту ошибку:
Ошибка: frames.content.document.getElementById ("FIELD_109094_DROPDOWN_null") равен нулю
Однако, если я использую следующий код, я могу по крайней мере изменить выбранный индекс выбранного элемента:
document.getElementById("FIELD_109094_DROPDOWN_null").selectedIndex = 2;
Я не могу понять, как запустить функцию updateDep
через скрипт Greasemonkey. Код в скрипте выглядит следующим образом:
// ==/UserScript==
var initElements = (function () {
var elementExists = document.getElementById("FIELD_109094_DROPDOWN_null");
if(elementExists)
{
document.getElementById("FIELD_109094_DROPDOWN_null").selectedIndex = 2;
frames["content"].updateDep(109094, frames["content"].document.getElementById("FIELD_109094_DROPDOWN_null").options[2].value);
}
}
)();
window.addEventListener('load', initElements, false);
Любая помощь будет принята с благодарностью.