JS метод Attr.getNamedItem()
Загальний опис
getNamedItem()
є методом об'єкта NamedNodeMap
, який повертає вузол (node) із заданим name
або null
, якщо такий вузол не знайдено. Цей метод часто використовується для отримання атрибутів елементів у документі XML або HTML.
Метод getNamedItem()
приймає один аргумент - рядок, який представляє ім'я шуканого атрибута. Наприклад, якщо ми маємо елемент <div id="myDiv" class="myClass">
, то getNamedItem('id')
поверне атрибут id
із значенням "myDiv"
, а getNamedItem('class')
поверне атрибут class
із значенням "myClass"
.
Розглянемо простий приклад використання getNamedItem()
в JavaScript:
const div = document.getElementsByTagName('div')[0];
const idAttr = div.attributes.getNamedItem('id');
console.log(idAttr.value); // Виведе значення атрибута id для першого div елемента
У цьому прикладі ми отримуємо перший div
елемент на сторінці використовуючи document.getElementsByTagName('div')[0]
. Потім ми отримуємо об'єкт NamedNodeMap
, який містить всі атрибути цього елемента через властивість attributes
. Нарешті, ми викликаємо getNamedItem('id')
на цьому об'єкті, щоб отримати атрибут id
, і виводимо його значення в консоль.
Метод getNamedItem()
також можна використовувати в циклах для перебору всіх атрибутів елемента:
const div = document.getElementsByTagName('div')[0];
const attrs = div.attributes;
for (let i = 0; i < attrs.length; i++) {
const attr = attrs.getNamedItem(attrs[i].name);
console.log(`Атрибут: ${attr.name}, Значення: ${attr.value}`);
}
У цьому прикладі ми проходимо циклом по всіх атрибутах div
елемента використовуючи attrs.length
. Для кожного атрибута ми викликаємо getNamedItem()
з іменем поточного атрибута attrs[i].name
, щоб отримати об'єкт атрибута, і виводимо його ім'я та значення в консоль.
getNamedItem()
також можна використовувати для перевірки наявності певного атрибута в елементі:
const div = document.getElementsByTagName('div')[0];
const idAttr = div.attributes.getNamedItem('id');
if (idAttr) {
console.log(`Елемент має атрибут id зі значенням ${idAttr.value}`);
} else {
console.log('Елемент не має атрибута id');
}
У цьому прикладі ми перевіряємо, чи повернув getNamedItem('id')
значення, відмінне від null
. Якщо атрибут id
присутній, ми виводимо його значення в консоль, інакше - повідомлення про відсутність цього атрибута.
Однак, слід пам'ятати, що getNamedItem()
є застарілим методом і в сучасному JavaScript існують більш зручні та гнучкі способи роботи з атрибутами елементів. Наприклад, можна використовувати властивість dataset
для зберігання та отримання даних, пов'язаних з елементом, або методи getAttribute()
та setAttribute()
для безпосереднього доступу до атрибутів.
Розглянемо приклад використання dataset
:
const div = document.createElement('div');
div.dataset.id = 'myDiv';
div.dataset.class = 'myClass';
console.log(div.dataset.id); // Виведе 'myDiv'
console.log(div.dataset.class); // Виведе 'myClass'
У цьому прикладі ми створюємо новий div
елемент і встановлюємо його властивості data-id
та data-class
за допомогою властивості dataset
. Потім ми можемо отримати ці значення, звертаючись до відповідних властивостей dataset
.
Також можна використовувати методи getAttribute()
та setAttribute()
:
const div = document.createElement('div');
div.setAttribute('id', 'myDiv');
div.setAttribute('class', 'myClass');
console.log(div.getAttribute('id')); // Виведе 'myDiv'
console.log(div.getAttribute('class')); // Виведе 'myClass'
У цьому прикладі ми створюємо новий div
елемент і встановлюємо його атрибути id
та class
за допомогою методу setAttribute()
. Потім ми можемо отримати значення цих атрибутів за допомогою методу getAttribute()
.
Хоча getNamedItem()
все ще може бути корисним у певних ситуаціях, наприклад, при роботі з існуючими XML/HTML документами, в цілому рекомендується використовувати сучасніші та більш зручні методи роботи з атрибутами та даними елементів, такі як dataset
, getAttribute()
та setAttribute()
.
Порада: | Хоча |
Порада: | Якщо |
Синтаксис
getNamedItem(name)
Параметри
- *
name
Рядок із назвою бажаного атрибута.
Return
Attr
Повертає об'єкт
Attr
, що відповідає наданому ім'я, абоnull
, якщо жоден не знайдено.
Переглядачі
Переглядач | |||||
---|---|---|---|---|---|
1 |
1 |
1 |
12.1 |
12 |
Переглядач | ||||
---|---|---|---|---|
4.4 |
18 |
4 |
1 |
Переглядач | ||
---|---|---|
- |
- |
Приклади
У цьому прикладі ми маємо поле вводу для введення імені атрибута та кнопку "Отримати атрибут". Коли користувач натискає на кнопку, ми викликаємо getNamedItem()
з введеним іменем атрибута на демонстраційному div
елементі. Якщо атрибут знайдено, ми виводимо його значення та, якщо це атрибут data-color
, змінюємо колір тексту div
елемента на вказане значення. Якщо атрибут не знайдено, ми виводимо відповідне повідомлення.
У цьому прикладі ми отримуємо значення атрибута id
першого елемента div
на сторінці за допомогою методу getNamedItem()
. Це показує один з найпростіших способів використання цього методу.
// Отримуємо перший елемент div на сторінці
const div = document.getElementsByTagName('div')[0];
// Отримуємо атрибут id цього елемента
const idAttr = div.attributes.getNamedItem('id');
// Виводимо значення атрибута id в консоль
console.log(idAttr.value);
У цьому прикладі ми перевіряємо наявність атрибута data-role
у всіх елементах div
на сторінці та виконуємо певні дії залежно від значення цього атрибута. Це демонструє використання getNamedItem()
у циклі та поєднання його з іншими операціями над атрибутами.
// Отримуємо всі елементи div на сторінці
const divs = document.getElementsByTagName('div');
// Проходимо циклом по всіх div елементах
for (let i = 0; i < divs.length; i++) {
const div = divs[i];
// Отримуємо атрибут data-role для поточного div елемента
const roleAttr = div.attributes.getNamedItem('data-role');
// Якщо атрибут data-role присутній
if (roleAttr) {
const role = roleAttr.value;
// Виконуємо різні дії залежно від значення атрибута
switch (role) {
case 'header':
div.style.backgroundColor = 'lightgray';
break;
case 'content':
div.style.padding = '10px';
break;
case 'footer':
div.style.textAlign = 'center';
break;
}
}
}