Задать вопрос
coolswood
@coolswood
https://coolswood.github.io

Как при клике на элемент с классом получить его значение?

Вроде бы банальная задача, но поставила меня в тупик. Контент генерируется постоянно (это субититры к видео). Каждое слово обернуто в div c классом, задача при клике правой кнопкой мыши получить значение и записать в переменную, при клике на следующее слово добавить значение. Я реализовал это следующим образом:
sub.addEventListener('mouseover', function (e) {
for (i = 0; i < chat.length; i++) {
        chat[i].addEventListener('contextmenu', function (e) {
            e.preventDefault();
            container += (this.innerText + ' ');
            this.style.background = 'lime';
            console.log(container)
        });
    }
}


То есть в начале я слушаю событие наведения, так как контент меняется. Потом при нажатии запускается перебор псевдомассива и записывается текущее значение. Но он записывает не одно значение, а дублирует его. Не могу понять как вывести из цикла одно значение.
И вообще подскажите правильный ли подход я использую?
  • Вопрос задан
  • 704 просмотра
Подписаться 1 Оценить Комментировать
Решения вопроса 1
tomgif
@tomgif
Веб-разработчик
Проблема в особенностях js, используйте замыкание
var container = '';
sub.addEventListener('mouseover', function (e) {
	for (i = 0; i < chat.length; i++) {
  
  	var text = (function(i){
  	
    		var container;
    
        chat[i].addEventListener('contextmenu', function (e) {
            e.preventDefault();
            container = this.innerText + ' ';
            this.style.background = 'lime';
        });
        
        return container;
		})(i);
    
    container += text;

   }
}


Подробнее
Ответ написан
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Похожие вопросы
Rocket Смоленск
от 80 000 до 130 000 ₽
div. Ставрополь
от 40 000 до 90 000 ₽
Wanted. Санкт-Петербург
До 220 000 ₽
18 дек. 2024, в 17:50
7000 руб./за проект
18 дек. 2024, в 17:26
5000 руб./за проект
18 дек. 2024, в 17:23
1500 руб./за проект