- Работа с атрибутами
- Изменения в jQuery-1.6
- В действии
- Ссылки
- .attr()
- Contents:
- .attr( attributeName ) Returns: String
- version added: 1.0 .attr( attributeName )
- Attributes vs. Properties
- Additional Notes:
- Examples:
- Работа с атрибутами в jQuery
- Методы attr() и removeAttr()
- Получение значения атрибута
- Изменение значения атрибута
- Добавление нового атрибута
- Как в jQuery удалить атрибут у элемента
Работа с атрибутами
Возвращает или изменяет значение атрибутов у выбранных элементов страницы. Функция имеет четыре варианта использования:
возвращает значение атрибута attrName у выбранного элемента. Если выбрано несколько элементов, то значение будет взято у первого.
группе аттрибутов attrName1, attrName2, . будут присвоены значения value1, value2, . , у всех выбранных элементов.
атрибуту attrName будет присвоено значение, возвращенное пользовательской функцией (если она ничего не вернет, то атрибут просто останется каким был до этого). Функция вызывается отдельно, для каждого из выбранных элементов. При вызове ей передаются следующие параметры: index — позиция элемента в наборе, value — текущее значение атрибута attrName у элемента.
$(«div»).attr(«class») | вернет имя класса у первого div-элемента на странице |
$(«div»).attr(«class», «divEl») | класс всех div-элементов на странице станет равным divEl |
$(«div»).attr() | класс div-элементов станет равен divEl, а title — «Див» |
$(«.rool»).attr(«title») | вернет подсказку элемента с классом rool. Если таких элементов на странице несколько — вернет первого из них. |
Замечание 1: важно отметить, что используя метод .attr(name), вы получите значения атрибута только первого элемента из всех выбранных. Если вам нужны значения всех элементов, то следует использовать конструкции типа .map() или .each().
Замечание 2: IE не позволяет менять атрибут type у элементов input и button.
Изменения в jQuery-1.6
Начиная с версии jQuery-1.6, при попытке получить значение атрибута, которым элемент не обладает, метод attr(attrName) вернет undefined. В более ранних версиях, вместо этого, в некоторых случаях, возвращалась пустая строка. Кроме того, начиная с версии jQuery-1.6 в jQuery разделены способы работы с атрибутами и свойствами DOM-объектов (разница между атрибутами и свойствами) и для последних стоит использовать prop(propName). В частности, разница при работе с атрибутами и свойствами существенна, когда идет речь об атрибутах не требующих указания значений (checked и disabled в input-элементах): допустим у нас есть элемент , а в переменной elem хранится его DOM-объект. В этом случае, работа со значением checked будет иметь следующие результаты:
elem.checked | true |
$(elem).prop(«checked») | true |
elem.getAttribute(«checked») | пустая строка. |
$(elem).attr(«checked») | пустая строка для jQuery-1.6+ и true для более ранних версий. |
В действии
найдем элемент с идентификатором newsBlock и поместим в него, значение его же класса:
~lt~!DOCTYPE html~gt~ ~lt~html~gt~ ~lt~head~gt~ ~lt~script src="https://code.jquery.com/jquery-latest.js"~gt~~lt~/script~gt~ ~lt~style~gt~ div, span < display: block; width: 50px; height: 50px; float: left; padding: 15px; margin: 5px; background-color: #EEEEEE; font-size: 12pt; >~lt~/style~gt~ ~lt~/head~gt~ ~lt~body~gt~ ~lt~div ~gt~ 1 ~lt~/div~gt~ ~lt~div ~gt~ 2 ~lt~/div~gt~ ~lt~div ~gt~ 3 ~lt~/div~gt~ ~lt~script~gt~ var className = $("#newsBlock").attr("class"); $("#newsBlock").text(className); ~lt~/script~gt~ ~lt~/body~gt~ ~lt~/html~gt~
Ссылки
- работа с атрибутами элементов страницы
- атрибуты элементов страницы
- значение атрибута
- получить значение атрибута
- изменить значение атрибута
- установить значение атрибута
- присвоить значение атрибуту
- .attr()
- attr()
.attr()
Get the value of an attribute for the first element in the set of matched elements or set one or more attributes for every matched element.
Contents:
.attr( attributeName ) Returns: String
Description: Get the value of an attribute for the first element in the set of matched elements.
version added: 1.0 .attr( attributeName )
The .attr() method gets the attribute value for only the first element in the matched set. To get the value for each element individually, use a looping construct such as jQuery’s .each() or .map() method.
Using jQuery’s .attr() method to get the value of an element’s attribute has two main benefits:
- Convenience: It can be called directly on a jQuery object and chained to other jQuery methods.
- Cross-browser consistency: The values of some attributes are reported inconsistently across browsers, and even across versions of a single browser. The .attr() method reduces such inconsistencies.
Note: Attribute values are strings with the exception of a few attributes such as value and tabindex.
As of jQuery 1.6, the .attr() method returns undefined for attributes that have not been set. To retrieve and change DOM properties such as the checked , selected , or disabled state of form elements, use the .prop() method.
Attributes vs. Properties
The difference between attributes and properties can be important in specific situations. Before jQuery 1.6, the .attr() method sometimes took property values into account when retrieving some attributes, which could cause inconsistent behavior. As of jQuery 1.6, the .prop() method provides a way to explicitly retrieve property values, while .attr() retrieves attributes.
For example, selectedIndex , tagName , nodeName , nodeType , ownerDocument , defaultChecked , and defaultSelected should be retrieved and set with the .prop() method. Prior to jQuery 1.6, these properties were retrievable with the .attr() method, but this was not within the scope of attr . These do not have corresponding attributes and are only properties.
Concerning boolean attributes, consider a DOM element defined by the HTML markup , and assume it is in a JavaScript variable named elem :
elem.checked | true (Boolean) Will change with checkbox state |
---|---|
$( elem ).prop( «checked» ) | true (Boolean) Will change with checkbox state |
elem.getAttribute( «checked» ) | «checked» (String) Initial state of the checkbox; does not change |
$( elem ).attr( «checked» ) (1.6+) | «checked» (String) Initial state of the checkbox; does not change |
$( elem ).attr( «checked» ) (pre-1.6) | true (Boolean) Changed with checkbox state |
According to the W3C forms specification, the checked attribute is a boolean attribute, which means the corresponding property is true if the attribute is present at all—even if, for example, the attribute has no value or is set to empty string value or even «false». This is true of all boolean attributes.
Nevertheless, the most important concept to remember about the checked attribute is that it does not correspond to the checked property. The attribute actually corresponds to the defaultChecked property and should be used only to set the initial value of the checkbox. The checked attribute value does not change with the state of the checkbox, while the checked property does. Therefore, the cross-browser-compatible way to determine if a checkbox is checked is to use the property:
The same is true for other dynamic attributes, such as selected and value .
Additional Notes:
- In Internet Explorer prior to version 9, using .prop() to set a DOM element property to anything other than a simple primitive value (number, string, or boolean) can cause memory leaks if the property is not removed (using .removeProp() ) before the DOM element is removed from the document. To safely set values on DOM objects without memory leaks, use .data() .
Examples:
Display the checked attribute and property of a checkbox as it changes.
Работа с атрибутами в jQuery
HTML-атрибуты – это дополнительные значения для установления различных характеристик HTML-элементам в HTML-коде. С помощью них можно определённым образом настроить элемент и отрегулировать его поведение. Все атрибуты указываются внутри открытого тега и отделяются друг от друга посредством пробела.
Кроме атрибутов у нас имеются ещё DOM-свойства , которые в большинстве случаев являются их отражением.
Образуются DOM-свойства во время чтения браузером HTML-кода, т.е. при строительстве DOM. DOM – это объектная модель документа. При её создании теги становятся элементами (узлами), а HTML-атрибуты переводятся в соответствующие DOM-свойства этих элементов.
Для сведений, атрибут, который мы устанавливаем в HTML-коде называется атрибутом содержимого . А DOM-свойство – IDL-атрибутом .
Более подробно прочитать про атрибуты, DOM-свойства и их отличия можно в этой статье.
В заключение можно отметить, что при написании кода на JavaScript зачастую лучше использовать именно DOM-свойства, а не соответствующие им атрибуты. Кстати, в jQuery для выполнения операций с DOM-свойствами имеется специальный метод prop() . Описывается он в этой статье.
А сейчас познакомимся с методами jQuery для работы с атрибутами.
Методы attr() и removeAttr()
В jQuery для выполнения действий над атрибутами имеется два метода:
- attr() – используется, когда нужно, узнать значение требуемого атрибута, добавить к элементу новый атрибут или изменить текущее значение некоторого атрибута на новое;
- removeAttr() – применяется для удаления определённого атрибута у элемента или набора элементов.
Получение значения атрибута
Узнать значение определённого атрибута в jQuery осуществляется через attr() :
// attributeName – атрибут, значение которого нужно получить .attr('attributeName')
Например, получим значение атрибута href элемента #search :
Яндекс
При применении attr() к набору элементов, этот метод вернёт значение указанного атрибута только для первого элемента.
. . .
Для того, чтобы вернуть значение указанного атрибута для каждого элемента набора, можно воспользоваться each() или map() .
$('.section').each(function() { console.log( $(this).attr('id') ); }); // Результат: // section-1 // section-2 // section-3
Если атрибута, значение которого мы хотим получить у элемента нет, то attr() вернёт undefined :
Этот сценарий можно использовать для проверки наличия определённого атрибута у элемента.
Например, проверим имеется ли у элемента #logo» атрибут title :
Изменение значения атрибута
Изменение значения атрибута осуществляется также посредством attr() .
Вариант синтаксиса attr() для установки значения одному атрибуту:
// attributeName – имя атрибута // value – новое значение (строка, число или null) .attr('attributeName', value)
Кстати, если установить атрибуту null , то он будет удалён.
Например, поменяем значение атрибута src элемента #logo :
Установка сразу нескольких атрибутов элементу осуществляется в формате объекта:
// attributes – объект, содержащий набор пар «атрибут: значение» .attr(attributes)
Пример установки элементу #logo несколько атрибутов:
Кроме этого в jQuery имеется также вариант установки атрибута с помощью функции:
// attr - имя атрибута .attr('attr', function(index, value) { // . })
В этом случае значение атрибута будет определяться результатом (строка или число), возвращаемой функцией. Если функция ничего не возвращает или undefined , то текущее значение не изменяется (оно остаётся прежним).
Обратиться к текущему элементу в функции можно с помощью ключевого слова this .
Добавление нового атрибута
В jQuery, установка нового атрибута или изменение существующего — это одна и также операция.
Пример, в котором всем ссылкам на странице установим атрибут rel со значением nofollow :
Как в jQuery удалить атрибут у элемента
В jQuery удаление атрибута обычно осуществляется с помощью метода removeAttr() :
// attributeName - атрибут, который нужно удалить .removeAttr('attributeName')
Например, удалим атрибут rel у всех ссылок на странице:
В jQuery удалить атрибут можно также с помощью attr() . Для этого ему нужно в качестве значения установить null .