Форум программистов, компьютерный форум, киберфорум
JavaScript
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.97/29: Рейтинг темы: голосов - 29, средняя оценка - 4.97
4 / 4 / 3
Регистрация: 14.10.2014
Сообщений: 323

Как узнать индекс нажатого элемента массива

12.11.2016, 12:17. Показов 6300. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Есть такой список:
HTML5
1
2
3
4
5
6
7
<ul id="navigation">
   <li class="nav active"></li>
   <li class="nav"></li>
   <li class="nav"></li>
   <li class="nav"></li>
   <li class="nav"></li>
</ul>
Как узнать индекс нажатого элемента? Вот что я делаю:
JavaScript
1
2
3
var nav = document.getElementsByClassName('nav');
nav.onclick = function() {
}
А дальше ничего не получается. Правильно я понимаю, nav - это массив?
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
12.11.2016, 12:17
Ответы с готовыми решениями:

Индекс "нажатого" элемента
Делаю элементы, при клике меняющие стиль. Вот код index.js class App extends React.Component { constructor(props) { ...

MainMenu - как узнать индекс нажатого меню?
Доброе утро, форумчане! Встретился с интереным для себя вопросом: А как узнать id элемента из MainMenu, который нажал пользователь? В...

Как определить индекс нажатого элемента pictureBox [, ]
Есть два массива с одинаковой размерности pictureBox picArray , int intArray . Нужно при нажатии на picArray изменить значение intArray ....

4
 Аватар для vettel
84 / 84 / 41
Регистрация: 14.02.2015
Сообщений: 320
12.11.2016, 12:27
Цитата Сообщение от maks_7 Посмотреть сообщение
Правильно я понимаю, nav - это массив?
Не совсем. Метод gelElementsByClass возвращает коллекцию, не массив. И эту коллекцию нужно перебрать в цикле, и на каждый элемент повесить обработчик. Допустим, так:
JavaScript
1
2
3
4
5
for(var i = 0; i < nav.length; ++i) {
    nav[i].onclick = function() {
        //do something
    }
}
1
4 / 4 / 3
Регистрация: 14.10.2014
Сообщений: 323
12.11.2016, 14:36  [ТС]
vettel, спасибо! vettel, почему-то не работает, не посмотрите?

HTML-код:

HTML5
1
2
3
4
5
6
7
<ul id="pagination">
   <li class="pag"></li>
   <li class="pag"></li>
   <li class="pag"></li>
   <li class="pag"></li>
   <li class="pag"></li>
</ul>
CSS - стили:
CSS
1
2
3
4
5
6
7
8
9
10
11
#pagination{
list-style-type: none;
}
.pag {
 display:inline-block;
 margin-right: 10px; 
 width:15px;
 height:15px;
 background-color: blue; 
 cursor:pointer;
}
Javascript:

JavaScript
1
2
3
4
5
for(var i = 0; i < pag.length; ++i) {
    pag[i].onclick = function() {
        alert(i);
    }
}
https://jsfiddle.net/vlad35/etLz9xg5/1/
0
392 / 294 / 121
Регистрация: 26.08.2016
Сообщений: 902
12.11.2016, 14:53
maks_7,
JavaScript
1
var nav = document.getElementsByClassName('nav');
забыли
1
4 / 4 / 4
Регистрация: 14.03.2016
Сообщений: 38
12.11.2016, 16:29
код не верный. Вспомните задачe на setTimeout и область видимости переменной i.
Когда будет действие то она будет равна 5 и все нажатия выведут 5!


JavaScript
1
2
3
4
5
6
7
8
9
10
11
var pag=document.getElementsByClassName('pag');
 
for(var i = 0; i < pag.length; ++i) {
    pag[i].onclick = (function(val){
    return function (){
    return console.log(val);
    }
    })(i);
        
  
}

немного проще будет добавить data-item=#; в список и проверять так nav.getAttribute('data-item')

удачи
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
12.11.2016, 16:29
Помогаю со студенческими работами здесь

Как узнать индекс элемента массива?
Доброго времени суток Подскажите пожалуйста как узнать индекс элемента массива?

Как узнать индекс у элемента массива?
Доброго времени суток. У меня есть массив GameObject`ов public GameObject spawnCells, в которых у меня находятся 25 клеток игрового поля. Я...

Как узнать индекс элемента массива, зная итератор на этот элемент?
Вот пример: #include &lt;iostream&gt; #include &lt;vector&gt; #include &lt;algorithm&gt; size_t get_index ( const...

Узнать Caption нажатого элемента ТPopupMenu
Здравствуйте. Есть Popupmenu с 7 елементами. Нужно сделать так, чтобы при нажатии на определенный елемент выводился его caption. Ето...

Узнать индекс максимального элемента второй половины массива
Нам нужно узнать номер максимального элемента второй половины массива t с 20 элементов


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Программный контроль заполнения реквизита табличной части документа
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: реализовать контроль заполнения реквизита табличной части. . .
wmic не является внутренней или внешней командой
Maks 02.04.2026
Решение: DISM / Online / Add-Capability / CapabilityName:WMIC~~~~ Отсюда: https:/ / winitpro. ru/ index. php/ 2025/ 02/ 14/ komanda-wmic-ne-naydena/
Программная установка даты и запрет ее изменения
Maks 02.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "СписаниеМатериалов", разработанного в конфигурации КА2. Задача: при создании документов установить период списания автоматически. . .
Вывод данных в справочнике через динамический список
Maks 01.04.2026
Реализация из решения ниже выполнена на примере нетипового справочника "Спецтехника" разработанного в конфигурации КА2. Задача: вывести данные из ТЧ нетипового документа. . .
Функция заполнения текстового поля в реквизите формы документа
Maks 01.04.2026
Алгоритм из решения ниже реализован на нетиповом документе "ВыдачаОборудованияНаСпецтехнику" разработанного в конфигурации КА2, в дополнении к предыдущему решению. На форме документа создается. . .
К слову об оптимизации
kumehtar 01.04.2026
Вспоминаю начало 2000-х, университет, когда я писал на Delphi. Тогда среди программистов на форумах активно обсуждали аккуратную работу с памятью: нужно было следить за переменными, вовремя. . .
Идея фильтра интернета (сервер = слой+фильтр).
Hrethgir 31.03.2026
Суть идеи заключается в том, чтобы запустить свой сервер, о чём я если честно мечтал давно и давно приобрёл книгу как это сделать. Но не было причин его запускать. Очумелые учёные напечатали на. . .
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru