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

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

15.01.2016, 14:03. Показов 23571. Ответов 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
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11680&amp;d=1772460536 Одним из. . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru