Форум программистов, компьютерный форум, киберфорум
JavaScript
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.85/125: Рейтинг темы: голосов - 125, средняя оценка - 4.85
 Аватар для Teamur
29 / 29 / 5
Регистрация: 06.01.2015
Сообщений: 336

Добавить/Удалить класс элементу с заданным классом по клику (без jQuery)

15.01.2016, 14:03. Показов 23519. Ответов 12
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Добавить/Удалить класс элементу с заданным классом по клику!
HTML5
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
<!doctype html>
<meta charset='utf-8'>
<title>ПРИМЕР</title>
<div class='el'>Element 1</div>
<div class='el'>Element 2</div>
<style>
  .el {
    background: #eef;
  }
  .red {
    color: #f00;
  }
</style>
<script>
  var el = document.querySelectorAll('.el');
  el.onclick = function() {
    this.classList.toggle('red');
  }
</script>
Пробовал и так:
JavaScript
1
2
3
4
  var el = document.getElementsByClassName('el');
  el.addEventListener('click', function() {
    this.classList.toggle('red');
  })
Не помогло (

Объясните, пожалуйста, почему не работает пример, если:
1) Код скрипта синтаксически правильный;
2) Он находится в конце документа, следовательно DOM будет уже загружен.

Причем, если использовать:
var el = document.querySelector('.el');
пример работает и, как положено, в случае с querySelector, находит первый элемент с классом .el и добавляет к нему класс .red
А мне нужно, чтобы цвет шрифта менялся на том элементе с классом .el, по которому я кликну!

Плюс, если не трудно, подскажите как можно максимально сократить скрипт, не используя при этом jQuery и тп.
Спасибо!
0
Лучшие ответы (1)
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
15.01.2016, 14:03
Ответы с готовыми решениями:

Добавить класс динамично добавленному элементу, без нажатия, фокуса, наведения
Здравствуйте! Как это реализовать (см. заголовок)? Есть такие реализации: $(parent).on('click', 'tag.class', function(){...}); ...

Присвоить класс элементу, который содержит в себе элемент с определенным классом (AJAX выдача)
Доброго времени! Есть выдача по AJAX-запросу - сетка блоков. Нужно подсветить блок, в котором есть блок с определенным классом. ...

Как добавлять класс _isactive через jQuery при 4 элементах с одинаковым классом
есть 4 кнопки &lt;div class=&quot;btn&quot;&gt;button 1&lt;/div&gt; &lt;div class=&quot;btn&quot;&gt;button 2&lt;/div&gt; &lt;div class=&quot;btn&quot;&gt;button 3&lt;/div&gt; &lt;div...

12
123 / 62 / 32
Регистрация: 10.01.2014
Сообщений: 241
15.01.2016, 14:23
Цитата Сообщение от Teamur Посмотреть сообщение
getElementsByClassName querySelectorAll
у вас в обоих случаях условно массив ( точнее в первом живая коллекция а во втором объект HTMLCollection) и у них нет метода addEventListener, пробегитесь по коллекции циклом и навешайте клик на елементы

Добавлено через 7 минут
JavaScript
1
2
3
4
5
6
7
8
9
10
11
  var elCollection = document.getElementsByClassName('el');
  console.dir(elCollection);
  var elNodes = document.querySelectorAll(".el");
  console.dir(elNodes);
  for(var i = 0; i < elCollection.length; i++) {
    var elem = elCollection[i];
    console.log(elem);
    elem.addEventListener("click", function(){
        this.classList.toggle("red");
    })
  }
0
 Аватар для Teamur
29 / 29 / 5
Регистрация: 06.01.2015
Сообщений: 336
15.01.2016, 14:24  [ТС]
scio me nescire,
Пробегитесь по коллекции циклом и навешайте клик на элементы

Этого я, честно говоря, не ожидал. Думал, что задача наипростейшая.
С циклами я еще пока не работал. Начинающий )

В связи с этим у меня 2 вопроса:
1) Можно ли обойтись БЕЗ циклов?
2) Как это сделать с циклом?
0
123 / 62 / 32
Регистрация: 10.01.2014
Сообщений: 241
15.01.2016, 14:34
Лучший ответ Сообщение было отмечено Teamur как решение

Решение

по поводу сократить

JavaScript
1
2
3
4
5
   for(var i = 0; i < document.getElementsByClassName('el').length; i++) {
    document.getElementsByClassName('el')[i].addEventListener("click", function(){
        this.classList.toggle("red");
    })
  }
Добавлено через 8 минут
Teamur,

Не по теме:

она и есть наипростейшая


вот без цикла
JavaScript
1
2
3
4
document.body.addEventListener("click", function(e){
    var elem = e.target
    if(elem.classList.contains("el")) elem.classList.toggle("red");
})
1
 Аватар для Teamur
29 / 29 / 5
Регистрация: 06.01.2015
Сообщений: 336
15.01.2016, 14:38  [ТС]
scio me nescire, Спасибо!
А что бы вы выбрали из предложенного вами?
Что быстрее работает?
Может быть есть еще какие варианты?
0
123 / 62 / 32
Регистрация: 10.01.2014
Сообщений: 241
15.01.2016, 14:42
Teamur, первый вариант наиболее очевидный, плюс не будет никаких проверок если кликнуть на другом теге, так что цикл лучше
0
 Аватар для Teamur
29 / 29 / 5
Регистрация: 06.01.2015
Сообщений: 336
15.01.2016, 14:54  [ТС]
А проверка требует времени. То есть клик на любом элементе страницы будет включать проверку его скриптом на наличие указанного в нем класса?

addEventListener нужно обязательно добавлять в данном примере, верно?
0
123 / 62 / 32
Регистрация: 10.01.2014
Сообщений: 241
15.01.2016, 15:02
Цитата Сообщение от Teamur Посмотреть сообщение
То есть клик на любом элементе страницы будет включать проверку его скриптом на наличие указанного в нем класса?
все верно, плюс такого подхода, что если у вас появятся еще елементы которыми нужно так же управлять, просто дописываете к ним класc el
в случае же с циклом такого не будет, цикл прошелся развешал обработчики и если после его прохода вы динамически добавите еще один <div class="el"></div> на нем уже такого обработчика не будет
вот: http://frontender.info/an-intr... hiksobtiya

Цитата Сообщение от Teamur Посмотреть сообщение
addEventListener нужно обязательно добавлять в данном примере, верно?
можно еще так
JavaScript
1
2
3
elem.click = function (){
    // код
};
1
 Аватар для Teamur
29 / 29 / 5
Регистрация: 06.01.2015
Сообщений: 336
15.01.2016, 15:08  [ТС]
А вот используя селектор для id, содержащего 'el'
можно организовать? То есть без классов, но с проверкой на наличие фрагмента из id (el в примере ниже)?

HTML5
1
2
3
4
5
6
7
8
9
10
11
12
<!doctype html>
<meta charset='utf-8'>
<title>ПРИМЕР</title>
<div id='el_1'>Element 1</div>
<div id='el_2'>Element 2</div>
 
<script>
var el = document.querySelector('div[id*='el']');
el.onclick = function() {
  this.classList.toggle('red');
}
</script>
Это я так гипотетически.. )))
0
123 / 62 / 32
Регистрация: 10.01.2014
Сообщений: 241
15.01.2016, 15:20
Teamur, методы onclick, addEventListener есть только у html елемента, а в el у вас лежит HTMLCollection
JavaScript
1
var el = [<div id='el_1'>Element 1</div>, <div id='el_2'>Element 2</div>]
, то есть фактически вы сейчас написали что то типа:

JavaScript
1
2
3
[<div id='el_1'>Element 1</div>, <div id='el_2'>Element 2</div>].onclick = function() {
  this.classList.toggle('red');
}
1
 Аватар для Teamur
29 / 29 / 5
Регистрация: 06.01.2015
Сообщений: 336
15.01.2016, 15:29  [ТС]
Другими словами, методы onclick и addEventListener могут работать только с одним элементом?
А если надо, чтобы с несколькими, нужно повесить обработчики на все интересующие элементы, пробежавшись по ним циклом!
0
123 / 62 / 32
Регистрация: 10.01.2014
Сообщений: 241
15.01.2016, 15:30
Teamur, да
0
 Аватар для Teamur
29 / 29 / 5
Регистрация: 06.01.2015
Сообщений: 336
15.01.2016, 15:38  [ТС]
Наверное другие товарищи вряд ли смогут предложить что-то еще. Всё, вроде, разжевали, как вы думаете, scio me nescire?
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
15.01.2016, 15:38
Помогаю со студенческими работами здесь

Добавить класс по клику
Подскажите пож - есть блок картинок с одним class , как сделать чтоб при клике по картинке ей добавлялся class activssss, а у других...

Добавить класс в зависимости от значения элементов с одинаковым классом
&lt;table&gt; &lt;tr&gt; &lt;td class=&quot;image&quot;&gt;&lt;/td&gt; &lt;td class=&quot;animal&quot;&gt;Петух&lt;/td&gt; &lt;td class=&quot;color&quot;&gt;Красный&lt;/td&gt; &lt;/tr&gt; &lt;tr&gt; &lt;td...

Добавить класс элементу
Привет! помогите пожалуйста разобраться, необходимо добавить класс блоку div (при нажатии на крестик модальное окно (popup) закрывается). ...

Добавить класс к элементу
Есть HTML: &lt;ul class=&quot;nav&quot;&gt; &lt;li&gt;&lt;a href=&quot;/page1&quot;&gt;PAGE1&lt;/a&gt;&lt;/li&gt; &lt;li&gt;&lt;a href=&quot;/page2&quot;&gt;PAGE2&lt;/a&gt;&lt;/li&gt; &lt;li&gt;&lt;a...

Сформировать одномерный массив. Удалить из него элемент с заданным номером, добавить элемент с заданным номеро
Сформировать одномерный массив. Удалить из него элемент с заданным номером, добавить элемент с заданным номером;


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
13
Ответ Создать тему
Новые блоги и статьи
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США. Нашел на реддите интересную статью под названием «Кто-нибудь знает, где получить бесплатный компьютер или. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru