Форум программистов, компьютерный форум, киберфорум
JavaScript
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/3: Рейтинг темы: голосов - 3, средняя оценка - 4.67
5 / 2 / 3
Регистрация: 21.06.2013
Сообщений: 117

Область видимости внутри for

04.12.2016, 13:04. Показов 661. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
var to_hide = document.getElementsByClassName('expand_full_review');
var expand = document.querySelector(".recal_link");
 
for (var i = 0; i < to_hide.length; ++i) {
    if (String(to_hide[i].innerText).length > 20) {
        to_hide[i].innerText = to_hide[i].innerText.substr(0,to_hide[i].innerText.indexOf(".")) + "...";
 
    
    expand.onclick = function() {
        console.log(to_hide[i]) //undefined
    }
}
}
при клике выводит undefined, но если вызвать
JavaScript
1
2
3
4
expand.onclick = function() {
console.log(to_hide)
console.log(i)
}
все работает, вопрос - почему?
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
04.12.2016, 13:04
Ответы с готовыми решениями:

Область видимости
Есть код,полностью рабочий,но это-то мне и странно,ведь переменная i1 определена в функции p1(), а значит только в ней и должна быть...

Область видимости
привет, почему в этом нет ошибки? Почему из edit вызывается Set? ведь у вызова this.Set() - this будет окружающая функция this.Edit, а в...

Область видимости
Здравствуйте есть один главный фал с функциями common.js, а к каждой странице подключается js файл, который нужен для неё. Например, для...

4
 Аватар для Пифагор
2172 / 1655 / 840
Регистрация: 10.01.2015
Сообщений: 5,207
04.12.2016, 14:11
Я тоже задавался этим вопросом, ибо была подобная ситуевина.
Решил просто: создал внутри анонимной функции еще одну var i
Надо было передавать Id дивов, которые были пронумерованы 1, 2, 3 и тд.

Добавлено через 6 минут
Если интересно, вот весь код
0
5 / 2 / 3
Регистрация: 21.06.2013
Сообщений: 117
04.12.2016, 14:51  [ТС]
Пифагор, что-то никак у меня не вышло, не понял я тот код
0
380 / 230 / 115
Регистрация: 22.11.2016
Сообщений: 379
04.12.2016, 22:08
JavaScript
1
2
3
expand.onclick = function() {
                console.log(to_hide[i-1]) //undefined
            }
0
 Аватар для Lazy_Den
3325 / 2845 / 1423
Регистрация: 15.01.2014
Сообщений: 6,170
04.12.2016, 23:14
fixeri, мне непонятны две вещи, которые косвенно относятся к вашей проблеме:
1. Почему в первом случае вы используете метод getElementsByClassName, а во втором - querySelector? Это мелочи, но всё же.
2. В "expand" будет один первый элемент с классом "recal_link", а элементов с классом "expand_full_review" - может быть несколько. Тогда зачем все эти манипуляции с обработчиком события?
Ну, да вам видней... надеюсь.
JavaScript
1
2
3
4
5
6
7
8
9
10
11
12
13
14
var to_hide = document.querySelectorAll('.expand_full_review'),
    expand = document.querySelector(".recal_link"),
    txt = '';
 
for (var i = 0; i < to_hide.length; ++i) {
    if ((txt = to_hide[i].innerText).length > 20) {
        to_hide[i].innerText = txt.substr(0, txt.indexOf(".")) + "...";
        (function(i) {
            expand.onclick = function() {
                console.log(to_hide[i])
            };
        }(i));
    }
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
04.12.2016, 23:14
Помогаю со студенческими работами здесь

глобальная область видимости
привет всем. прочитал что переменные обьявляются ключом Var для того, чтобы определить её область видимости. так вот назрел следующий...

Область видимости переменных
Здравствуйте, у меня существует проблема с областью видимости переменных вот в этом коде: ... xhr.onload = function() { try ...

Область видимости переменных
Из метода loader.load, который подгружает модель часов, нужно передать значение в переменную var stats = 0. var stats = 0; ... ...

Теоретический про область видимости
Привет, есть мой &quot;класс&quot; и в нем метод который недоступен из вне, на него забиндин клик по div'у. Вопрос, как javascript может вызвать...

События в javascript и область их видимости
совершенно запутался как организованы события. //у нас есть элемент (якорь) var button = document.createElement('a'); //ставим...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
Переходник USB-CAN-GPIO
Eddy_Em 20.03.2026
Достаточно давно на работе возникла необходимость в переходнике CAN-USB с гальваноразвязкой, оный и был разработан. Однако, все меня терзала совесть, что аж 48-ногий МК используется так тупо: просто. . .
Оттенки серого
Argus19 18.03.2026
Оттенки серого Нашёл в интернете 3 прекрасных модуля: Модуль класса открытия диалога открытия/ сохранения файла на Win32 API; Модуль класса быстрого перекодирования цветного изображения в оттенки. . .
SDL3 для Desktop (MinGW): Рисуем цветные прямоугольники с помощью рисовальщика SDL3 на Си и C++
8Observer8 17.03.2026
Содержание блога Финальные проекты на Си и на C++: finish-rectangles-sdl3-c. zip finish-rectangles-sdl3-cpp. zip
Символические и жёсткие ссылки в Linux.
algri14 15.03.2026
Существует два типа ссылок — символические и жёсткие. Ссылка в Linux — это запись в каталоге, которая может указывать либо на inode «файла-ИСТОЧНИКА», тогда это будет «жёсткая ссылка» (hard link),. . .
[Owen Logic] Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора
ФедосеевПавел 14.03.2026
Поддержание уровня воды в резервуаре количеством включённых насосов: моделирование и выбор регулятора ВВЕДЕНИЕ Выполняя задание на управление насосной группой заполнения резервуара,. . .
делаю науч статью по влиянию грибов на сукцессию
anaschu 13.03.2026
прикрепляю статью
SDL3 для Desktop (MinGW): Создаём пустое окно с нуля для 2D-графики на SDL3, Си и C++
8Observer8 10.03.2026
Содержание блога Финальные проекты на Си и на C++: hello-sdl3-c. zip hello-sdl3-cpp. zip Результат:
Установка CMake и MinGW 13.1 для сборки С и C++ приложений из консоли и из Qt Creator в EXE
8Observer8 10.03.2026
Содержание блога MinGW - это коллекция инструментов для сборки приложений в EXE. CMake - это система сборки приложений. Здесь описаны базовые шаги для старта программирования с помощью CMake и. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru