Перейти к содержимому

Attr jquery что это

  • автор:

Работа с атрибутами в jQuery

HTML-атрибуты – это дополнительные значения для установления различных характеристик 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() .

JavaScript

$('.section').each(function() { console.log( $(this).attr('id') ); }); // Результат: // section-1 // section-2 // section-3

Если атрибута, значение которого мы хотим получить у элемента нет, то attr() вернёт undefined :

.

Этот сценарий можно использовать для проверки наличия определённого атрибута у элемента.

Например, проверим имеется ли у элемента #logo» атрибут title :

 .   

Изменение значения атрибута

Изменение значения атрибута осуществляется также посредством attr() .

Вариант синтаксиса attr() для установки значения одному атрибуту:

JavaScript

// attributeName – имя атрибута // value – новое значение (строка, число или null) .attr('attributeName', value)

Кстати, если установить атрибуту null , то он будет удалён.

Например, поменяем значение атрибута src элемента #logo :

    

Установка сразу нескольких атрибутов элементу осуществляется в формате объекта:

JavaScript

// attributes – объект, содержащий набор пар «атрибут: значение» .attr(attributes)

Пример установки элементу #logo несколько атрибутов:

   

Кроме этого в jQuery имеется также вариант установки атрибута с помощью функции:

JavaScript

// attr - имя атрибута .attr('attr', function(index, value) { // . })

В этом случае значение атрибута будет определяться результатом (строка или число), возвращаемой функцией. Если функция ничего не возвращает или undefined , то текущее значение не изменяется (оно остаётся прежним).

Обратиться к текущему элементу в функции можно с помощью ключевого слова this .

  • index — индекс элемента в наборе;
  • valueAttr — текущее значение атрибута;
  • One
  • Two
  • Three
  • Four
  • Five

Добавление нового атрибута

В jQuery, установка нового атрибута или изменение существующего — это одна и также операция.

Пример, в котором всем ссылкам на странице установим атрибут rel со значением nofollow :

JavaScript

$('a').attr('rel', 'nofollow');
   

Как в jQuery удалить атрибут у элемента

В jQuery удаление атрибута обычно осуществляется с помощью метода removeAttr() :

JavaScript

// attributeName - атрибут, который нужно удалить .removeAttr('attributeName')

Например, удалим атрибут rel у всех ссылок на странице:

JavaScript

$('a[rel]').removeAttr('rel');

В jQuery удалить атрибут можно также с помощью attr() . Для этого ему нужно в качестве значения установить null .

$('a[rel]').attr('rel', null);

Ещё темы этого раздела:

  • Добавление и удаление DOM-свойств (disabled, checked, selected и др.)
  • Добавление и удаление классов
  • Получение и установка CSS-свойств элементам
  • data-атрибуты и внутреннее хранилище jQuery

.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.

.attr( attributeName ) Возвращает: String

Описание: Get the value of an attribute for the first element in the set of matched elements.

Добавлен в версии: 1.0 .attr( attributeName )

attributeName
The name of the attribute to get.

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:

  1. Convenience: It can be called directly on a jQuery object and chained to other jQuery methods.
  2. 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» ) (1.6.1+) «checked» (String) Will change with checkbox state
$( 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:

  • if ( elem.checked )
  • if ( $( elem ).prop( «checked» ) )
  • if ( $( elem ).is( «:checked» ) )

The same is true for other dynamic attributes, such as selected and value .

Дополнительные замечания:

  • 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() .

.attr( attributeName, value ) Возвращает: jQuery

Описание: Set one or more attributes for the set of matched elements.

Добавлен в версии: 1.0 .attr( attributeName, value )

attributeName
The name of the attribute to set.
value
Тип: String or Number or Null

A value to set for the attribute. If null , the specified attribute will be removed (as in .removeAttr() ).

Добавлен в версии: 1.0 .attr( attributes )

attributes
An object of attribute-value pairs to set.

Добавлен в версии: 1.1 .attr( attributeName, function )

attributeName
The name of the attribute to set.
function
Тип: Function( Integer index, String attr ) => String or Number

A function returning the value to set. this is the current element. Receives the index position of the element in the set and the old attribute value as arguments.

The .attr() method is a convenient way to set the value of attributes—especially when setting multiple attributes or using values returned by a function. Consider the following image:

img id="greatphoto" src="brush-seller.jpg" alt="brush seller">
Setting a simple attribute

To change the alt attribute, simply pass the name of the attribute and its new value to the .attr() method:

$( "#greatphoto" ).attr( "alt", "Beijing Brush Seller" );

Add an attribute the same way:

$( "#greatphoto" ).attr( "title", "Photo by Kelly Clark" );
Setting several attributes at once

To change the alt attribute and add the title attribute at the same time, pass both sets of names and values into the method at once using a plain JavaScript object. Each key-value pair in the object adds or modifies an attribute:

$( "#greatphoto" ).attr(
alt: "Beijing Brush Seller",
title: "photo by Kelly Clark"
>);

When setting multiple attributes, the quotes around attribute names are optional.

WARNING: When setting the 'class' attribute, you must always use quotes!

Note: Attempting to change the type attribute on an input or button element created via document.createElement() will throw an exception on Internet Explorer 8 or older.

Computed attribute values

By using a function to set attributes, you can compute the value based on other properties of the element. For example, to concatenate a new value with an existing value:

$( "#greatphoto" ).attr( "title", function( i, val )
return val + " - photo by Kelly Clark";
>);

This use of a function to compute attribute values can be particularly useful when modifying the attributes of multiple elements at once.

Note: If nothing is returned in the setter function (ie. function(index, attr)<> ), or if undefined is returned, the current value is not changed. This is useful for selectively setting values only when certain criteria are met.

  • Ajax
    • Глобальные Ajax события
    • Вспомогательные методы
    • Низкоуровневый интерфейс
    • Сокращенные методы
    • Базовые
    • Пользовательские
    • Затухание
    • Скольжение
    • События браузера
    • Загрузка документа
    • Прикрепление обработчиков
    • Объект событие
    • События формы
    • События клавиатуры
    • События мыши
    • Class атрибут
    • Копирование
    • DOM Вставка вокруг
    • DOM Вставка внутрь
    • DOM Вставка вне
    • DOM Удаление
    • DOM Замена
    • Общие аттрибуты
    • Свойства стилей
    • Манипуляция коллекциями
    • Хранилище данных
    • DOM методы элементов
    • Методы установки
    • Экземпляр объекта jQuery
    • Глобальный объект jQuery
    • Атрибут
    • Базовые
    • Базовые фильтры
    • Фильтры потомков
    • Фильтры содержимого
    • Форма
    • Иерархия
    • jQuery расширение
    • Фильтр видимости
    • Фильтрация
    • Обход
    • Обход элементов
    • Версия 1.3
    • Версия 1.7
    • Версия 1.8
    • Версия 1.9
    • Версия 1.10
    • Версия 3.0

    Русская документация по jQuery.
    При использовании любых материалов с сайта ссылка на сайт обязательна.

    Атрибуты и свойства

    »» В данной статье используется исходный код для примеров. Сохраните эту страницу для тестирования приведенных ниже примеров.

    Библиотека jQuery позволяет получать и устанавливать значения атрибутов элементов, содержащихся в объекте jQuery. Методы jQuery, предназначенные для работы с атрибутами, описаны в таблице ниже:

    Методы для работы с атрибутами

    Метод Описание
    attr(имя) Возвращает значение атрибута с указанным именем для первого из элементов, содержащихся в объекте jQuery
    attr(имя, значение) Устанавливает значение атрибута с указанным именем для всех элементов, содержащихся в объекте jQuery
    attr(объект отображения) Устанавливает атрибуты, указанные в объекте отображения, для всех элементов, содержащихся в объекте jQuery
    attr(имя, функция) Устанавливает указанный атрибут для всех элементов, содержащихся в объекте jQuery, с помощью функции
    removeAttr(имя), removeAttr(имя[]) Удаляет атрибут (атрибуты) из всех элементов, содержащихся в объекте jQuery
    prop(имя) Возвращает значение указанного свойства для первого из элементов, содержащихся в объекте jQuery
    prop(имя, значение), prop(объект отображения) Устанавливает значение одного или нескольких свойств для всех элементов, содержащихся в объекте jQuery
    prop(имя, функция) Устанавливает значение указанного свойства для всех элементов, содержащихся в объекте jQuery, с использованием функции
    removeProp(имя) Удаляет указанное свойство из всех элементов, содержащихся в объекте jQuery

    Если метод attr() вызывается с одним аргументом, jQuery возвращает значение указанного атрибута для первого из элементов выбранного набора. Соответствующий пример приведен ниже:

    $(function() < var srcValue = $('img').attr('src'); console.log("Значение атрибута: " + srcValue); >);

    В этом сценарии мы выбираем все элементы img в документе, а затем используем метод attr() для получения значения атрибута src, при считывании которого получаем строку. На консоль выводится следующий результат:

    Применение метода attr() с одним аргументом

    Получение значения атрибута для всех элементов, содержащихся в объекте jQuery, обеспечивается совместным применением методов each() и attr():

    $(function() < var srcValue = $('img').each(function(index, element) < console.log('Значение атрибута src: ' + $(this).attr('src')); >); >);

    В этом сценарии из объекта HTMLElement, передаваемого функции в качестве аргумента, с помощью функции $() создается объект jQuery. Этот объект содержит единственный элемент, который идеально подходит для метода attr().

    Установка значений атрибутов

    Если метод attr() используется для установки значения атрибута, то изменение применяется ко всем элементам, содержащимся в объекте jQuery. Таким образом, в данном случае метод ведет себя иначе, чем при считывании атрибутов, когда возвращается лишь значение атрибута одного элемента. При установке атрибута метод attr() возвращает объект jQuery, что означает возможность использования цепочки вызовов.

    Пример сценария, выполняющего установку значения атрибута, приведен ниже:

    $(function() < $('img').attr("src", "http://professorweb.ru/downloads/jquery/lily.png"); >);

    В этом сценарии выбираются все элементы img в документе, и для атрибута src устанавливается ссылка на картинку lily.png. Установленное значение применяется ко всем выбранным элементам, как показано на рисунке:

    Установка одного и того же значения атрибута для нескольких элементов

    Установка нескольких атрибутов

    Можно установить значения нескольких атрибутов одним вызовом метода attr(), передав ему в качестве аргумента объект. Свойства такого объекта интерпретируются как имена атрибутов, а значения свойств — как значения атрибута. Этот объект принято называть . Соответствующий пример приведен ниже:

    $(function() < var attrValues = < src: 'http://professorweb.ru/downloads/jquery/lily.png', style: 'border: thick solid red' >; $('img').attr(attrValues); >);

    В этом сценарии создается объект, определяющий свойства с именами src и style. Далее в документе выбираются элементы img, и методу attr() передается объект отображения. Вид страницы в окне браузера приведен на рисунке:

    Установка значений нескольких атрибутов с помощью метода attr()

    Динамическая установка значений атрибутов

    Назначаемые атрибутам значения можно определять во время выполнения сценария, передавая методу attr() функцию в качестве аргумента. Соответствующий пример приведен ниже:

    $(function() < $('img').attr("src", function(index, oldVal) < if (oldVal.indexOf("rose") >-1) < return "http://professorweb.ru/downloads/jquery/lily.png"; >else if ($(this).closest('#row2').length > 0) < return "http://professorweb.ru/downloads/jquery/carnation.png"; >>); >);

    Аргументы, передаваемые указанной функции, — это индекс обрабатываемого элемента в наборе и прежнее значение атрибута. Переменная this ссылается на текущий обрабатываемый объект HTMLElement. Если вы хотите изменить атрибут, то функция должна вернуть строку, содержащую новое значение. Если же результат не возвращается, то используется прежнее значение атрибута. В данном примере функция используется для избирательного изменения изображений, отображаемых элементами img.

    Удаление атрибутов

    Атрибуты можно удалять (отменять установку) с помощью метода removeAttr(), как показано в примере ниже:

    $(function() < $('img').attr("style", "border: thick solid red"); $('img:odd').removeAttr("style"); >);

    В этом примере атрибут style сначала устанавливается с помощью метода attr(), а затем удаляется из нечетных элементов img с помощью метода removeAttr(). Вид страницы в окне браузера приведен на рисунке:

    Удаление атрибутов из элементов

    Работа со свойствами

    Каждому варианту метода attr() соответствует аналогичный вариант вызова метода prop(). Различие между обоими методами состоит в том, что методы prop() имеют дело со свойствами, определяемыми объектами HTMLElement, а не со значениями атрибутов. Часто атрибуты и соответствующие свойства имеют одинаковые имена, но это не всегда так. В качестве простого примера можно привести атрибут class, представленный в объекте HTMLElement свойством className.

    Пример использования метода prop() для получения значения этого свойства приведен ниже:

    $(function() < $('*[class]').each(function(index, elem) < console.log("Элемент:" + elem.tagName + " " + $(elem).prop("className")); >); >);

    В этом примере сначала выбираются в виде набора, а затем последовательно перебираются с помощью метода each() все элементы, у которых имеется атрибут class. Для каждого элемента на консоль выводится его тип и значение свойства className.

    Урок №11 - Работа с атрибутами

    Урок №11 - Работа с атрибутами

    В видео мы научимся работать с различными атрибутами. Мы научимся добавлять атрибуты, проверять атрибуты и совершать действия в зависимости от значения атрибута.

    Видеоурок

    jQuery дает большие возможности при работе с различными атрибутами HTML тегов. За счёт jQuery вы можете добавить класс, id, подсказку и множество других атрибутов к любому тегу.

    Чтобы добавить атрибут к тегу необходимо выбрать тег через jQuery и применить к нему метод attr () . Он принимает два параметра: название атрибута, а также его значение.

    $("p:last-child").attr("title", "Это последний абзац в документе");

    В коде выше мы добавляем всплывающую подсказку к последнему абзацу на HTML-странице.

    Весь код будет доступен после подписки на проект!

Добавить комментарий

Ваш адрес email не будет опубликован. Обязательные поля помечены *