Вход/Регистрация
JavaScript. Подробное руководство, 6-е издание
вернуться

Флэнаган Дэвид

Шрифт:

Обратите внимание, что в этом разделе описываются не сам язык разметки HTML, а приемы управления HTML-формами. Здесь предполагается, что вы уже имеете некоторое знакомство с HTML-элементами (

<input>, <textarea>, <select>
и т. д), используемыми для создания форм. Тем не менее в табл. 15.1 для справки приводится список наиболее часто используемых элементов форм. Дополнительные сведения о функциях для работы с формами и элементами форм можно узнать в четвертой части книги, в справочных статьях
Form, Input, Option, Select
и
TextArea
.

15.9.1. Выбор форм и элементов форм

Формы и элементы, содержащиеся в них, можно выбрать с помощью стандартных методов, таких как

getElementByld
и
getElementsByTagName:

var fields = document.getElementById("address").getElementsByTagName("input");

В броузерах, поддерживающих

querySelectorAll,
можно выбрать все радиокнопки или все элементы с одинаковыми именами, присутствующие в форме, как показано ниже:

// Все радиокнопки в форме с атрибутом id=”shipping"

document.querySelectorAll('«shipping input[type="radio"]');

// Все радиокнопки с атрибутом name="method" в форме с атрибутом id="shipping"

document.querySelectorAll('«shipping input[type="radio"][name="method"]');

Однако, как описывалось в разделах 14.7,15.2.2 и 15.2.3, элемент

<form>
с установленным атрибутом
name
или
id
можно также выбрать другими способами. Элемент
<form>
с атрибутом
name="address"
можно выбрать любым из следующих способов:

window.address // Ненадежный: старайтесь не использовать

document.address // Может применяться только к формам с атрибутом name

document.forms.address // Явное обращение к форме с атрибутом name или id

document.forms[n] // Ненадежный: n - порядковый номер формы

В разделе 15.2.3 говорилось, что свойство

document.forms
ссылается на объект
HTMLCollection
, позволяющий выбирать элементы
<form>
по их порядковым номерам, по значению атрибута
id
или
name
. Объекты
Form
сами по себе действуют подобно объектам
HTMLCollection
, хранящим элементы форм, и могут индексироваться именами или числами. Если первый элемент формы с атрибутом
name="address"
имеет атрибут
name="street”
, на него можно сослаться с помощью любого из следующих выражений:

document.forms.address[0]

document.forms.address.street

document.address.street // только для name="address", но не id=”address”

Если необходимо явно указать, что выполняется обращение к элементу формы, вместо объекта формы можно индексировать его свойство

elements
:

document.forms.address.elements[0]

document.forms.address.elements.street

Для выбора конкретных элементов документа предпочтительнее использовать атрибут

id
. Однако при отправке форм атрибут
name
играет особую роль и чаще используется с самими формами, чем с элементами форм. Обычно при работе с группами флажков и обязательно при работе с группами радиокнопок для атрибута
name
используется одно и то же значение. Напомню, что, когда объект
HTMLCollection
индексируется именем и существует сразу несколько элементов, использующих одно и то же имя, возвращаемым значением является объект, подобный массиву, содержащий все элементы с указанным именем. Взгляните на следующую форму, содержащую радиокнопки для выбора метода доставки товара:

<form name="shipping">

<fieldset>

<legend>Shipping Method</legend>

<label>

<input type="radio" name="method" value="1st">

первым классом

</1аbеl>

<label>

  • Читать дальше
  • 1
  • ...
  • 257
  • 258
  • 259
  • 260
  • 261
  • 262
  • 263
  • 264
  • 265
  • 266
  • 267
  • ...

Ебукер (ebooker) – онлайн-библиотека на русском языке. Книги доступны онлайн, без утомительной регистрации. Огромный выбор и удобный дизайн, позволяющий читать без проблем. Добавляйте сайт в закладки! Все произведения загружаются пользователями: если считаете, что ваши авторские права нарушены – используйте форму обратной связи.

Полезные ссылки

  • Моя полка

Контакты

  • chitat.ebooker@gmail.com

Подпишитесь на рассылку: