![]() ![]() колонтитул в word 2007, 0000002111
Контейнер FORM и поля форм в JavaScriptЕсли рассматривать программирование на JavaScript в исторической перспективе, то первыми объектами, для которых были разработаны методы и свойства, стали поля форм. Обычно контейнер FORM и поля форм именованы:
<FORM NAME=f_name METHOD=get ACTION="javascript:void(0);"> <INPUT NAME=i_name SIZE=30 MAXLENGTH=30> </FORM> window.document.f_name.i_name.value="Текстовое поле"; Того же эффекта можно достичь, используя массив форм загруженного документа: window.document.forms[0].elements[0].value="Текстовое поле"; В данном примере не только к форме, но и к полю формы мы обращаемся как к элементу массива. Рассмотрим подробнее объект Form, который соответствует контейнеру FORM.
Сами по себе методы, свойства и события объекта Form
используются нечасто. Их переопределение обычно связано с реакцией на изменения
значений полей формы. 1. actionСвойство action отвечает за вызов скрипта (CGI-скрипта). В нем указывается его (скрипта) URL. Но там, где можно указать URL, можно указать и его схему javascript:
<FORM METHOD=post ACTION="javascript:window.alert('We use JavaScript-code as an URL'); void(0);"> <INPUT TYPE=submit VALUE="Продемонстрировать JavaScript в action"> </FORM> 2. elements[]При генерации встроенного в документ объекта Form браузер создает и связанный с ним массив полей формы. Обычно к полям обращаются по имени, но можно обращаться и по индексу массива полей формы:
<FORM NAME=fe> <INPUT NAME=fe1 SIZE=30 MAXLENGTH=30> <INPUT TYPE=button VALUE="Ввести текст по имени" onClick="document.fe.fe1.value='Ввести текст по имени';"> <INPUT TYPE=button VALUE="Ввести текст по индексу" onClick="document.fe.elements[0].value='Ввести текст по индексу';"> <INPUT TYPE=reset VALUE="Очистить"> </FORM>
document.forms[i].elements.length. 3. reset()Метод reset(), не путать с обработчиком события onReset, позволяет установить значения полей формы по умолчанию. При этом использовать кнопку типа Reset не требуется:
<FORM NAME=r> <INPUT VALUE="Значение по умолчанию" SIZE=30 MAXLENGTH=30> <INPUT TYPE=button VALUE="Изменим текст в поле ввода" onClick="document.r.elements[0].value='Изменили текст';"> </FORM> <A HREF="javascript:document.r.reset();void(0);"> Установили значение по умолчанию</A> 4. submit()Метод submit() позволяет проинициировать передачу введенных в форму данных на сервер. При этом методом submit() инициируется тот же процесс, что и нажатием на кнопку типа Submit. Это позволяет отложить выполнение передачи данных на сервер:
<FORM NAME=s METHOD=post ACTION="javascript:window.alert('Данные подтверждены');void(0);"> Введите цифру или букву:<INPUT SIZE=1 MAXLENGTH=1> </FORM> <A HREF="javascript:document.s.submit();">Отправить данные</A> 5. onResetСобытие reset (восстановление значений по умолчанию в полях формы) возникает при нажатии на кнопку типа Reset или при выполнении метода reset(). В контейнере FORM можно переопределить функцию обработки данного события.Для этой цели в него введен атрибут onReset:
<FORM onReset="javascript:window.alert( 'Event Reset');return false;"> <INPUT VALUE="Значение по умолчанию"> <INPUT TYPE=reset VALUE="Восстановить"> </FORM> 6. onSubmitСобытие submit возникает при нажатии на кнопку типа Submit, графическую кнопку (тип image) или при вызове метода submit(). Для переопределения метода обработки события submit в контейнер FORM добавлен атрибут onSubmit.Функция, определенная в этом атрибуте, будет выполняться перед тем, как отправить данные на сервер. При этом в зависимости от того, что функция вернет в качестве значения, данные либо будут отправлены, либо нет.
function test() { if(parseInt(document.sub.digit.value).toString()=="NaN") { window.alert("Некорректные данные в поле формы."); return false; } else { return true; }} ... <FORM NAME=sub onSubmit="return test();" METHOD=post ACTION="javascript:window.alert('Данные подтверждены');void(0);"> <INPUT NAME=digit SIZE=1 MAXLENGTH=1><INPUT TYPE=submit VALUE="Отправить"> </FORM> В этом примере следует обратить внимание на конструкцию return test();. Сама функция test() возвращает значения true или false. Соответственно, данные либо отправляются на сервер, либо нет. Поля ввода (контейнер INPUT типа TEXT) являются одним из наиболее популярных объектов программирования на JavaScript. Это объясняется тем, что, помимо использования по прямому назначению, их применяют и в целях отладки программ, вводя в эти поля промежуточные значения переменных и свойств объектов.
<FORM>Число гипертекстовых ссылок: <INPUT SIZE=10 MAXLENGHT=10 VALUE="&{document.links.length};"> В данном примере первое поле формы — это поле ввода. Используя подстановку, мы присваиваем ему значение по умолчанию, а потом при помощи кнопки изменяем это значение. Объект Text (текстовое поле ввода) характеризуется следующими свойствами, методами и событиями:
Свойства объекта Text — это стандартный набор свойств поля формы. В полях ввода можно изменять только значение свойства value.
Обычно при программировании полей ввода решают
две типовых задачи: защита поля от ввода данных пользователем и реакция
на изменение значения поля ввода. колонтитулы в word 2007, 000000211111
Рекомендуем в повседневной деятельности:
![]() ![]() |